blob: 89838efadc375bbdde5449d944fc72008c52f589 [file] [log] [blame]
willy tarreau036e1ce2005-12-17 13:46:33 +01001ChangeLog :
2===========
willy tarreau4302f492005-12-18 01:00:37 +01003
Willy Tarreaufc0ad292023-03-10 16:28:37 +010042023/03/10 : 2.8-dev5
5 - MINOR: ssl: rename confusing ssl_bind_kws
6 - BUG/MINOR: config: crt-list keywords mistaken for bind ssl keywords
7 - BUG/MEDIUM: http-ana: Detect closed SC on opposite side during body forwarding
8 - BUG/MEDIUM: stconn: Don't rearm the read expiration date if EOI was reached
9 - MINOR: global: Add an option to disable the data fast-forward
10 - MINOR: haproxy: Add an command option to disable data fast-forward
11 - REGTESTS: Remove unsupported feature command in http_splicing.vtc
12 - BUG/MEDIUM: wdt: fix wrong thread being checked for sleeping
13 - BUG/MINOR: sched: properly report long_rq when tasks remain in the queue
14 - BUG/MEDIUM: sched: allow a bit more TASK_HEAVY to be processed when needed
15 - MINOR: threads: add flags to know if a thread is started and/or running
16 - MINOR: h3/hq-interop: handle no data in decode_qcs() with FIN set
17 - BUG/MINOR: mux-quic: transfer FIN on empty STREAM frame
18 - BUG/MINOR: mworker: prevent incorrect values in uptime
19 - MINOR: h3: add traces on decode_qcs callback
20 - BUG/MINOR: quic: Possible unexpected counter incrementation on send*() errors
21 - MINOR: quic: Add new traces about by connection RX buffer handling
22 - MINOR: quic: Move code to wakeup the timer task to avoid anti-amplication deadlock
23 - BUG/MINOR: quic: Really cancel the connection timer from qc_set_timer()
24 - MINOR: quic: Simplication for qc_set_timer()
25 - MINOR: quic: Kill the connections on ICMP (port unreachable) packet receipt
26 - MINOR: quic: Add traces to qc_kill_conn()
27 - MINOR: quic: Make qc_dgrams_retransmit() return a status.
28 - BUG/MINOR: quic: Missing call to task_queue() in qc_idle_timer_do_rearm()
29 - MINOR: quic: Add a trace to identify connections which sent Initial packet.
30 - MINOR: quic: Add <pto_count> to the traces
31 - BUG/MINOR: quic: Do not probe with too little Initial packets
32 - BUG/MINOR: quic: Wrong initialization for io_cb_wakeup boolean
33 - BUG/MINOR: quic: Do not drop too small datagrams with Initial packets
34 - BUG/MINOR: quic: Missing padding for short packets
35 - MINOR: quic: adjust request reject when MUX is already freed
36 - BUG/MINOR: quic: also send RESET_STREAM if MUX released
37 - BUG/MINOR: quic: acknowledge STREAM frame even if MUX is released
38 - BUG/MINOR: h3: prevent hypothetical demux failure on int overflow
39 - MEDIUM: h3: enforce GOAWAY by resetting higher unhandled stream
40 - MINOR: mux-quic: define qc_shutdown()
41 - MINOR: mux-quic: define qc_process()
42 - MINOR: mux-quic: implement client-fin timeout
43 - MEDIUM: mux-quic: properly implement soft-stop
44 - MINOR: quic: mark quic-conn as jobs on socket allocation
45 - MEDIUM: quic: trigger fast connection closing on process stopping
46 - MINOR: mux-h2/traces: do not log h2s pointer for dummy streams
47 - MINOR: mux-h2/traces: add a missing TRACE_LEAVE() in h2s_frt_handle_headers()
48 - BUG/MEDIUM: quic: Missing TX buffer draining from qc_send_ppkts()
49 - DEBUG: stream: Add a BUG_ON to never exit process_stream with an expired task
50 - DOC: config: Fix description of options about HTTP connection modes
51 - MINOR: proxy: Only consider backend httpclose option for server connections
52 - BUG/MINOR: haproxy: Fix option to disable the fast-forward
53 - DOC: config: Add the missing tune.fail-alloc option from global listing
54 - MINOR: cfgcond: Implement strstr condition expression
55 - MINOR: cfgcond: Implement enabled condition expression
56 - REGTESTS: Skip http_splicing.vtc script if fast-forward is disabled
57 - REGTESTS: Fix ssl_errors.vtc script to wait for connections close
58 - BUG/MINOR: mworker: stop doing strtok directly from the env
59 - BUG/MEDIUM: mworker: prevent inconsistent reload when upgrading from old versions
60 - BUG/MEDIUM: mworker: don't register mworker_accept_wrapper() when master FD is wrong
61 - MINOR: startup: HAPROXY_STARTUP_VERSION contains the version used to start
62 - BUG/MINOR: cache: Cache response even if request has "no-cache" directive
63 - BUG/MINOR: cache: Check cache entry is complete in case of Vary
64 - MINOR: compiler: add a TOSTR() macro to turn a value into a string
65 - BUG/MINOR: lua/httpclient: missing free in hlua_httpclient_send()
66 - BUG/MEDIUM: httpclient/lua: fix a race between lua GC and hlua_ctx_destroy
67 - MEDIUM: channel: Remove CF_READ_NOEXP flag
68 - MAJOR: channel: Remove flags to report READ or WRITE errors
69 - DEBUG: stream/trace: Add sedesc flags in trace messages
70 - MINOR: channel/stconn: Move rto/wto from the channel to the stconn
71 - MEDIUM: channel/stconn: Move rex/wex timer from the channel to the sedesc
72 - MEDIUM: stconn: Don't requeue the stream's task after I/O
73 - MEDIUM: stconn: Replace read and write timeouts by a unique I/O timeout
74 - MEDIUM: stconn: Add two date to track successful reads and blocked sends
75 - MINOR: applet/stconn: Add a SE flag to specify an endpoint does not expect data
76 - MAJOR: stream: Use SE descriptor date to detect read/write timeouts
77 - MINOR: stream: Dump the task expiration date in trace messages
78 - MINOR: stream: Report rex/wex value using the sedesc date in trace messages
79 - MINOR: stream: Use relative expiration date in trace messages
80 - MINOR: stconn: Always report READ/WRITE event on shutr/shutw
81 - CLEANUP: stconn: Remove old read and write expiration dates
82 - MINOR: stconn: Set half-close timeout using proxy settings
83 - MINOR: stconn: Remove half-closed timeout
84 - REGTESTS: cache: Use rxresphdrs to only get headers for 304 responses
85 - MINOR: stconn: Add functions to set/clear SE_FL_EXP_NO_DATA flag from endpoint
86 - BUG/MINOR: proto_ux: report correct error when bind_listener fails
87 - BUG/MINOR: protocol: fix minor memory leak in protocol_bind_all()
88 - MINOR: proto_uxst: add resume method
89 - MINOR: listener/api: add lli hint to listener functions
90 - MINOR: listener: add relax_listener() function
91 - MINOR: listener: workaround for closing a tiny race between resume_listener() and stopping
92 - MINOR: listener: make sure we don't pause/resume bypassed listeners
93 - BUG/MEDIUM: listener: fix pause_listener() suspend return value handling
94 - BUG/MINOR: listener: fix resume_listener() resume return value handling
95 - BUG/MEDIUM: resume from LI_ASSIGNED in default_resume_listener()
96 - MINOR: listener: pause_listener() becomes suspend_listener()
97 - BUG/MEDIUM: listener/proxy: fix listeners notify for proxy resume
98 - BUG/MINOR: sock_unix: match finalname with tempname in sock_unix_addrcmp()
99 - MEDIUM: proto_ux: properly suspend named UNIX listeners
100 - MINOR: proto_ux: ability to dump ABNS names in error messages
101 - MINOR: haproxy: always protocol unbind on startup error path
102 - BUILD: quic: 32-bits compilation issue with %zu in quic_rx_pkts_del()
103 - BUG/MINOR: ring: do not realign ring contents on resize
104 - MEDIUM: ring: make the offset relative to the head/tail instead of absolute
105 - CLEANUP: ring: remove the now unused ring's offset
106 - MINOR: config: add HAPROXY_BRANCH environment variable
107 - BUILD: thead: Fix several 32 bits compilation issues with uint64_t variables
108 - BUG/MEDIUM: fd: avoid infinite loops in fd_add_to_fd_list and fd_rm_from_fd_list
109 - BUG/MEDIUM: h1-htx: Never copy more than the max data allowed during parsing
110 - BUG/MINOR: stream: Remove BUG_ON about the task expiration in process_stream()
111 - MINOR: stream: Handle stream's timeouts in a dedicated function
112 - MEDIUM: stream: Eventually handle stream timeouts when exiting process_stream()
113 - MINOR: stconn: Report a send activity when endpoint is willing to consume data
114 - BUG/MEDIUM: stconn: Report a blocked send if some output data are not consumed
115 - MEDIUM: mux-h1: Don't expect data from server as long as request is unfinished
116 - MEDIUM: mux-h2: Don't expect data from server as long as request is unfinished
117 - MEDIUM: mux-quic: Don't expect data from server as long as request is unfinished
118 - DOC: config: Clarify the meaning of 'hold' in the 'resolvers' section
119 - DOC: config: Replace TABs by spaces
120 - BUG/MINOR: fd: used the update list from the fd's group instead of tgid
121 - BUG/MEDIUM: fd: make fd_delete() support being called from a different group
122 - CLEANUP: listener: only store conn counts for local threads
123 - MINOR: tinfo: make thread_set functions return nth group/mask instead of first
124 - MEDIUM: quic: improve fatal error handling on send
125 - MINOR: quic: consider EBADF as critical on send()
126 - BUG/MEDIUM: connection: Clear flags when a conn is removed from an idle list
127 - BUG/MINOR: mux-h1: Don't report an error on an early response close
128 - BUG/MINOR: http-check: Don't set HTX_SL_F_BODYLESS flag with a log-format body
129 - BUG/MINOR: http-check: Skip C-L header for empty body when it's not mandatory
130 - BUG/MINOR: http-fetch: recognize IPv6 addresses in square brackets in req.hdr_ip()
131 - REGTEST: added tests covering smp_fetch_hdr_ip()
132 - MINOR: quic: simplify return path in send functions
133 - MINOR: quic: implement qc_notify_send()
134 - MINOR: quic: purge txbuf before preparing new packets
135 - MEDIUM: quic: implement poller subscribe on sendto error
136 - MINOR: quic: notify on send ready
137 - BUG/MINOR: http-ana: Don't increment conn_retries counter before the L7 retry
138 - BUG/MINOR: http-ana: Do a L7 retry on read error if there is no response
139 - BUG/MEDIUM: http-ana: Don't close request side when waiting for response
140 - BUG/MINOR: mxu-h1: Report a parsing error on abort with pending data
141 - MINOR: ssl: Destroy ocsp update http_client during cleanup
142 - MINOR: ssl: Reinsert ocsp update entries later in case of unknown error
143 - MINOR: ssl: Add ocsp update success/failure counters
144 - MINOR: ssl: Store specific ocsp update errors in response and update ctx
145 - MINOR: ssl: Add certificate's path to certificate_ocsp structure
146 - MINOR: ssl: Add 'show ssl ocsp-updates' CLI command
147 - MINOR: ssl: Add sample fetches related to OCSP update
148 - MINOR: ssl: Use dedicated proxy and log-format for OCSP update
149 - MINOR: ssl: Reorder struct certificate_ocsp members
150 - MINOR: ssl: Increment OCSP update replay delay in case of failure
151 - MINOR: ssl: Add way to dump ocsp response in base64
152 - MINOR: ssl: Add global options to modify ocsp update min/max delay
153 - REGTESTS: ssl: Fix ocsp update crt-lists
154 - REGTESTS: ssl: Add test for new ocsp update cli commands
155 - MINOR: ssl: Add ocsp-update information to "show ssl crt-list"
156 - BUG/MINOR: ssl: Fix ocsp-update when using "add ssl crt-list"
157 - MINOR: ssl: Replace now.tv_sec with date.tv_sec in ocsp update task
158 - BUG/MINOR: ssl: Use 'date' instead of 'now' in ocsp stapling callback
159 - BUG/MEDIUM: quic: properly handle duplicated STREAM frames
160 - BUG/MINOR: cli: fix CLI handler "set anon global-key" call
161 - MINOR: http_ext: adding some documentation, forgot to inline function
162 - BUG/MINOR: quic: Do not send too small datagrams (with Initial packets)
163 - MINOR: quic: Add a BUG_ON_HOT() call for too small datagrams
164 - BUG/MINOR: quic: Ensure to be able to build datagrams to be retransmitted
165 - BUG/MINOR: quic: v2 Initial packets decryption failed
166 - MINOR: quic: Add traces about QUIC TLS key update
167 - BUG/MINOR: quic: Remove force_ack for Initial,Handshake packets
168 - BUG/MINOR: quic: Ensure not to retransmit packets with no ack-eliciting frames
169 - BUG/MINOR: quic: Do not resend already acked frames
170 - BUG/MINOR: quic: Missing detections of amplification limit reached
171 - MINOR: quic: Send PING frames when probing Initial packet number space
172 - BUG/MEDIUM: quic: do not crash when handling STREAM on released MUX
173 - BUG/MAJOR: fd/thread: fix race between updates and closing FD
174 - BUG/MEDIUM: dns: ensure ring offset is properly reajusted to head
175 - BUG/MINOR: mux-quic: properly init STREAM frame as not duplicated
176 - MINOR: quic: Do not accept wrong active_connection_id_limit values
177 - MINOR: quic: Store the next connection IDs sequence number in the connection
178 - MINOR: quic: Typo fix for ACK_ECN frame
179 - MINOR: quic: RETIRE_CONNECTION_ID frame handling (RX)
180 - MINOR: quic: Useless TLS context allocations in qc_do_rm_hp()
181 - MINOR: quic: Add spin bit support
182 - MINOR: quic: Add transport parameters to "show quic"
183 - BUG/MEDIUM: sink/forwarder: ensure ring offset is properly readjusted to head
184 - BUG/MINOR: dns: fix ring offset calculation on first read
185 - BUG/MINOR: dns: fix ring offset calculation in dns_resolve_send()
186 - MINOR: jwt: Add support for RSA-PSS signatures (PS256 algorithm)
187 - MINOR: h3: add traces on h3_init_uni_stream() error paths
188 - MINOR: quic: create a global list dedicated for closing QUIC conns
189 - MINOR: quic: handle new closing list in show quic
190 - MEDIUM: quic: release closing connections on stopping
191 - BUG/MINOR: quic: Wrong RETIRE_CONNECTION_ID sequence number check
192 - MINOR: fd/cli: report the polling mask in "show fd"
193 - CLEANUP: sock: always perform last connection updates before wakeup
194 - MINOR: quic: Do not stress the peer during retransmissions of lost packets
195 - BUG/MINOR: init: properly detect NUMA bindings on large systems
196 - BUG/MINOR: thread: report thread and group counts in the correct order
197 - BUG/MAJOR: fd/threads: close a race on closing connections after takeover
198 - MINOR: debug: add random delay injection with "debug dev delay-inj"
199 - BUG/MINOR: mworker: use MASTER_MAXCONN as default maxconn value
200 - BUG/MINOR: quic: Missing listener accept queue tasklet wakeups
201 - MINOR: quic_sock: un-statify quic_conn_sock_fd_iocb()
202 - DOC: config: fix typo "dependeing" in bind thread description
203 - DOC/CLEANUP: fix typos
204
Willy Tarreauc80560b2023-02-14 16:55:17 +01002052023/02/14 : 2.8-dev4
206 - BUG/MINOR: stats: fix source buffer size for http dump
207 - BUG/MEDIUM: stats: fix resolvers dump
208 - BUG/MINOR: stats: fix ctx->field update in stats_dump_proxy_to_buffer()
209 - BUG/MINOR: stats: fix show stats field ctx for servers
210 - BUG/MINOR: stats: fix STAT_STARTED behavior with full htx
211 - MINOR: quic: Update version_information transport parameter to draft-14
212 - BUG/MINOR: stats: Prevent HTTP "other sessions" counter underflows
213 - BUG/MEDIUM: thread: fix extraneous shift in the thread_set parser
214 - BUG/MEDIUM: listener/thread: bypass shards setting on failed thread resolution
215 - BUG/MINOR: ssl/crt-list: warn when a line is malformated
216 - BUG/MEDIUM: stick-table: do not leave entries in end of window during purge
217 - BUG/MINOR: clock: do not mix wall-clock and monotonic time in uptime calculation
218 - BUG/MEDIUM: cache: use the correct time reference when comparing dates
219 - MEDIUM: clock: force internal time to wrap early after boot
220 - BUILD: ssl/ocsp: ssl_ocsp-t.h depends on ssl_sock-t.h
221 - MINOR: ssl/ocsp: add a function to check the OCSP update configuration
222 - MINOR: cfgparse/server: move (min/max)conn postparsing logic into dedicated function
223 - BUG/MINOR: server/add: ensure minconn/maxconn consistency when adding server
224 - BUG/MEDIUM: stconn: Schedule a shutw on shutr if data must be sent first
225 - BUG/MEDIUM: quic: fix crash when "option nolinger" is set in the frontend
226 - MINOR: quic: implement a basic "show quic" CLI handler
227 - MINOR: quic: display CIDs and state in "show quic"
228 - MINOR: quic: display socket info on "show quic"
229 - MINOR: quic: display infos about various encryption level on "show quic"
230 - MINOR: quic: display Tx stream info on "show quic"
231 - MINOR: quic: filter closing conn on "show quic"
232 - BUG/MINOR: quic: fix filtering of closing connections on "show quic"
233 - BUG/MEDIUM: stconn: Don't needlessly wake the stream on send during fast-forward
234 - BUG/MINOR: quic: fix type bug on "show quic" for 32-bits arch
235 - BUG/MINOR: mworker: fix uptime for master process
236 - BUG/MINOR: clock/stats: also use start_time not start_date in HTML info
237 - BUG/MEDIUM: stconn: stop to enable/disable reads from streams via si_update_rx
238 - BUG/MEDIUM: quic: Buffer overflow when looking through QUIC CLI keyword list
239 - DOC: proxy-protocol: fix wrong byte in provided example
240 - MINOR: ssl-ckch: Stop to test CF_WRITE_ERROR to commit CA/CRL file
241 - MINOR: bwlim: Remove useless test on CF_READ_ERROR to detect the last packet
242 - BUG/MINOR: http-ana: Fix condition to set LAST termination flag
243 - BUG/MINOR: mux-h1: Don't report an H1C error on client timeout
244 - BUG/MEDIUM: spoe: Don't set the default traget for the SPOE agent frontend
245 - BUG/MINOR: quic: Wrong datagram dispatch because of qc_check_dcid()
246 - BUG/CRITICAL: http: properly reject empty http header field names
247
Willy Tarreaue74d77b2023-02-04 10:51:05 +01002482023/02/04 : 2.8-dev3
249 - BUG/MINOR: sink: make sure to always properly unmap a file-backed ring
250 - DEV: haring: add a new option "-r" to automatically repair broken files
251 - BUG/MINOR: ssl: Fix leaks in 'update ssl ocsp-response' CLI command
252 - MINOR: ssl: Remove debug fprintf in 'update ssl ocsp-response' cli command
253 - MINOR: connection: add a BUG_ON() to detect destroying connection in idle list
254 - MINOR: mux-quic/h3: send SETTINGS as soon as transport is ready
255 - BUG/MINOR: h3: fix GOAWAY emission
256 - BUG/MEDIUM: mux-quic: fix crash on H3 SETTINGS emission
257 - BUG/MEDIUM: hpack: fix incorrect huffman decoding of some control chars
258 - BUG/MINOR: log: release global log servers on exit
259 - BUG/MINOR: ring: release the backing store name on exit
260 - BUG/MINOR: sink: free the forwarding task on exit
261 - CLEANUP: trace: remove the QUIC-specific ifdefs
262 - MINOR: trace: add a TRACE_ENABLED() macro to determine if a trace is active
263 - MINOR: trace: add a trace_no_cb() dummy callback for when to use no callback
264 - MINOR: trace: add the long awaited TRACE_PRINTF()
265 - MINOR: h2: add h2_phdr_to_ist() to make ISTs from pseudo headers
266 - MEDIUM: mux-h2/trace: add tracing support for headers
267 - CLEANUP: mux-h2/trace: shorten the name of the header enc/dec functions
268 - DEV: hpack: fix `trash` build regression
269 - MINOR: http_htx: add http_append_header() to append value to header
270 - MINOR: http_htx: add http_prepend_header() to prepend value to header
271 - MINOR: sample: add ARGC_OPT
272 - MINOR: proxy: introduce http only options
273 - MINOR: proxy/http_ext: introduce proxy forwarded option
274 - REGTEST: add ifnone-forwardfor test
275 - MINOR: proxy: move 'forwardfor' option to http_ext
276 - MINOR: proxy: move 'originalto' option to http_ext
277 - MINOR: http_ext: introduce http ext converters
278 - MINOR: http_ext: add rfc7239_is_valid converter
279 - MINOR: http_ext: add rfc7239_field converter
280 - MINOR: http_ext: add rfc7239_n2nn converter
281 - MINOR: http_ext: add rfc7239_n2np converter
282 - REGTEST: add RFC7239 forwarded header tests
283 - OPTIM: http_ext/7239: introduce c_mode to save some space
284 - MINOR: http_ext/7239: warn the user when fetch is not available
285 - MEDIUM: proxy/http_ext: implement dynamic http_ext
286 - MINOR: cfgparse/http_ext: move post-parsing http_ext steps to http_ext
287 - DOC: config: fix option spop-check proxy compatibility
288 - BUG/MINOR: fcgi-app: prevent 'use-fcgi-app' in default section
289 - DOC: config: 'http-send-name-header' option may be used in default section
290 - BUG/MINOR: mux-h2: Fix possible null pointer deref on h2c in _h2_trace_header()
291 - BUG/MINOR: http_ext/7239: ipv6 dumping relies on out of scope variables
292 - BUG/MEDIUM: h3: do not crash if no buf space for trailers
293 - OPTIM: h3: skip buf realign if no trailer to encode
294 - MINOR: mux-quic/h3: define stream close callback
295 - BUG/MEDIUM: h3: handle STOP_SENDING on control stream
296 - BUG/MINOR: h3: reject RESET_STREAM received for control stream
297 - MINOR: h3: add missing traces on closure
298 - BUG/MEDIUM: ssl: wrong eviction from the session cache tree
299 - BUG/MINOR: h3: fix crash due to h3 traces
300 - BUG/MINOR: h3: fix crash due to h3 traces
301 - BUG/MEDIUM: thread: consider secondary threads as idle+harmless during boot
302 - BUG/MINOR: stats: use proper buffer size for http dump
303 - BUILD: makefile: fix PCRE overriding specific lib path
304 - MINOR: quic: remove fin from quic_stream frame type
305 - MINOR: quic: ensure offset is properly set for STREAM frames
306 - MINOR: quic: define new functions for frame alloc
307 - MINOR: quic: refactor frame deallocation
308 - MEDIUM: quic: implement a retransmit limit per frame
309 - MINOR: quic: add config for retransmit limit
310 - OPTIM: htx: inline the most common memcpy(8)
311 - CLEANUP: quic: no need for atomics on packet refcnt
312 - MINOR: stats: add by HTTP version cumulated number of sessions and requests
313 - BUG/MINOR: quic: Possible stream truncations under heavy loss
314 - BUG/MINOR: quic: Too big PTO during handshakes
315 - MINOR: quic: Add a trace about variable states in qc_prep_fast_retrans()
316 - BUG/MINOR: quic: Do not ignore coalesced packets in qc_prep_fast_retrans()
317 - MINOR: quic: When probing Handshake packet number space, also probe the Initial one
318 - BUG/MAJOR: quic: Possible crash when processing 1-RTT during 0-RTT session
319 - MEDIUM: quic: Remove qc_conn_finalize() from the ClientHello TLS callbacks
320 - BUG/MINOR: quic: Unchecked source connection ID
321 - MEDIUM: listener: move the analysers mask to the bind_conf
322 - MINOR: listener: move maxseg and tcp_ut to bind_conf
323 - MINOR: listener: move maxaccept from listener to bind_conf
324 - MINOR: listener: move the backlog setting from listener to bind_conf
325 - MINOR: listener: move the maxconn parameter to the bind_conf
326 - MINOR: listener: move the ->accept callback to the bind_conf
327 - MINOR: listener: remove the useless ->default_target field
328 - MINOR: listener: move the nice field to the bind_conf
329 - MINOR: listener: move the NOLINGER option to the bind_conf
330 - MINOR: listener: move the NOQUICKACK option to the bind_conf
331 - MINOR: listener: move the DEF_ACCEPT option to the bind_conf
332 - MINOR: listener: move TCP_FO to bind_conf
333 - MINOR: listener: move the ACC_PROXY and ACC_CIP options to bind_conf
334 - MINOR: listener: move LI_O_UNLIMITED and LI_O_NOSTOP to bind_conf
335 - MINOR: listener: get rid of LI_O_TCP_L4_RULES and LI_O_TCP_L5_RULES
336 - CLEANUP: listener: remove the now unused options field
337 - MINOR: listener: remove the now useless LI_F_QUIC_LISTENER flag
338 - CLEANUP: config: remove test for impossible case regarding bind thread mask
339 - MINOR: thread: add a simple thread_set API
340 - MEDIUM: listener/config: make the "thread" parser rely on thread_sets
341 - CLEANUP: config: stop using bind_tgroup and bind_thread
342 - CLEANUP: listener/thread: remove now unused bind_conf's bind_tgroup/bind_thread
343 - CLEANUP: listener/config: remove the special case for shards==1
344 - MEDIUM: config: restrict shards, not bind_conf to one group each
345 - BUG/MEDIUM: quic: do not split STREAM frames if no space
346 - BUILD: thread: fix build warnings with older gcc compilers
347
Willy Tarreau0f29b342023-01-22 14:20:57 +01003482023/01/22 : 2.8-dev2
349 - CLEANUP: htx: fix a typo in an error message of http_str_to_htx
350 - DOC: config: added optional rst-ttl argument to silent-drop in action lists
351 - BUG/MINOR: ssl: Fix crash in 'update ssl ocsp-response' CLI command
352 - BUG/MINOR: ssl: Crash during cleanup because of ocsp structure pointer UAF
353 - MINOR: ssl: Create temp X509_STORE filled with cert chain when checking ocsp response
354 - MINOR: ssl: Only set ocsp->issuer if issuer not in cert chain
355 - MINOR: ssl: Release ssl_ocsp_task_ctx.cur_ocsp when destroying task
356 - MINOR: ssl: Detect more OCSP update inconsistencies
357 - BUG/MINOR: ssl: Fix OCSP_CERTID leak when same certificate is used multiple times
358 - MINOR: ssl: Limit ocsp_uri buffer size to minimum
359 - MINOR: ssl: Remove mention of ckch_store in error message of cli command
360 - MINOR: channel: Don't test CF_READ_NULL while CF_SHUTR is enough
361 - REORG: channel: Rename CF_READ_NULL to CF_READ_EVENT
362 - REORG: channel: Rename CF_WRITE_NULL to CF_WRITE_EVENT
363 - MEDIUM: channel: Use CF_READ_EVENT instead of CF_READ_PARTIAL
364 - MEDIUM: channel: Use CF_WRITE_EVENT instead of CF_WRITE_PARTIAL
365 - MINOR: channel: Remove CF_READ_ACTIVITY
366 - MINOR: channel: Remove CF_WRITE_ACTIVITY
367 - MINOR: channel: Remove CF_ANA_TIMEOUT and report CF_READ_EVENT instead
368 - MEDIUM: channel: Remove CF_READ_ATTACHED and report CF_READ_EVENT instead
369 - MINOR: channel: Stop to test CF_READ_ERROR flag if CF_SHUTR is enough
370 - MINOR: channel/applets: Stop to test CF_WRITE_ERROR flag if CF_SHUTW is enough
371 - DOC: management: add details on "Used" status
372 - DOC: management: add details about @system-ca in "show ssl ca-file"
373 - BUG/MINOR: mux-quic: fix transfer of empty HTTP response
374 - MINOR: mux-quic: add traces for flow-control limit reach
375 - MAJOR: mux-quic: rework stream sending priorization
376 - MEDIUM: h3: send SETTINGS before STREAM frames
377 - MINOR: mux-quic: use send-list for STOP_SENDING/RESET_STREAM emission
378 - MINOR: mux-quic: use send-list for immediate sending retry
379 - BUG/MINOR: h1-htx: Remove flags about protocol upgrade on non-101 responses
380 - BUG/MINOR: hlua: Fix Channel.line and Channel.data behavior regarding the doc
381 - BUG/MINOR: resolvers: Wait the resolution execution for a do_resolv action
382 - BUG/MINOR: ssl: Remove unneeded pointer check in ocsp cli release function
383 - BUG/MINOR: ssl: Missing ssl_conf pointer check when checking ocsp update inconsistencies
384 - DEV: tcploop: add minimal support for unix sockets
385 - BUG/MEDIUM: listener: duplicate inherited FDs if needed
386 - BUG/MINOR: ssl: OCSP minimum update threshold not properly set
387 - MINOR: ssl: Treat ocsp-update inconsistencies as fatal errors
388 - MINOR: ssl: Do not wake ocsp update task if update tree empty
389 - MINOR: ssl: Reinsert updated ocsp response later in tree in case of http error
390 - REGTEST: ssl: Add test for 'update ssl ocsp-response' CLI command
391 - OPTIM: global: move byte counts out of global and per-thread
392 - BUG/MEDIUM: peers: make "show peers" more careful about partial initialization
393 - BUG/MINOR: promex: Don't forget to consume the request on error
394 - MINOR: http-ana: Add a function to set HTTP termination flags
395 - MINOR: http-ana: Use http_set_term_flags() in most of HTTP analyzers
396 - BUG/MINOR: http-ana: Report SF_FINST_R flag on error waiting the request body
397 - MINOR: http-ana: Use http_set_term_flags() when waiting the request body
398 - BUG/MINOR: http-fetch: Don't block HTTP sample fetch eval in HTTP_MSG_ERROR state
399 - MAJOR: http-ana: Review error handling during HTTP payload forwarding
400 - CLEANUP: http-ana: Remove HTTP_MSG_ERROR state
401 - BUG/MEDIUM: mux-h2: Don't send CANCEL on shutw when response length is unkown
402 - MINOR: htx: Add an HTX value for the extra field is payload length is unknown
403 - BUG/MINOR: http-ana: make set-status also update txn->status
404 - BUG/MINOR: listeners: fix suspend/resume of inherited FDs
405 - DOC: config: fix wrong section number for "protocol prefixes"
406 - DOC: config: fix aliases for protocol prefixes "udp4@" and "udp6@"
407 - DOC: config: mention the missing "quic4@" and "quic6@" in protocol prefixes
408 - MINOR: listener: also support "quic+" as an address prefix
409 - CLEANUP: stconn: always use se_fl_set_error() to set the pending error
410 - BUG/MEDIUM: stconn: also consider SE_FL_EOI to switch to SE_FL_ERROR
411 - MINOR: quic: Useless test about datagram destination addresses
412 - MINOR: quic: Disable the active connection migrations
413 - MINOR: quic: Add "no-quic" global option
414 - MINOR: sample: Add "quic_enabled" sample fetch
415 - MINOR: quic: Replace v2 draft definitions by those of the final 2 version
416 - BUG/MINOR: mux-fcgi: Correctly set pathinfo
417 - DOC: config: fix "Address formats" chapter syntax
418 - BUG/MEDIUM: jwt: Properly process ecdsa signatures (concatenated R and S params)
419 - BUILD: ssl: add ECDSA_SIG_set0() for openssl < 1.1 or libressl < 2.7
420 - Revert "BUILD: ssl: add ECDSA_SIG_set0() for openssl < 1.1 or libressl < 2.7"
421 - BUG/MINOR: ssl: Fix compilation with OpenSSL 1.0.2 (missing ECDSA_SIG_set0)
422 - BUG/MINOR: listener: close tiny race between resume_listener() and stopping
423 - BUG/MINOR: h3: properly handle connection headers
424 - MINOR: h3: extend function for QUIC varint encoding
425 - MINOR: h3: implement TRAILERS encoding
426 - BUG/MINOR: bwlim: Check scope for period expr for set-bandwitdh-limit actions
427 - MEDIUM: bwlim: Support constants limit or period on set-bandwidth-limit actions
428 - BUG/MINOR: bwlim: Fix parameters check for set-bandwidth-limit actions
429 - MINOR: h3: implement TRAILERS decoding
430 - BUG/MEDIUM: fd/threads: fix again incorrect thread selection in wakeup broadcast
431 - BUG/MINOR: thread: always reload threads_enabled in loops
432 - MINOR: threads: add a thread_harmless_end() version that doesn't wait
433 - BUG/MEDIUM: debug/thread: make the debug handler not wait for !rdv_requests
434 - BUG/MINOR: mux-h2: make sure to produce a log on invalid requests
435 - BUG/MINOR: mux-h2: add missing traces on failed headers decoding
436 - BUILD: hpack: include global.h for the trash that is needed in debug mode
437 - BUG/MINOR: jwt: Wrong return value checked
438 - BUG/MINOR: quic: Do not request h3 clients to close its unidirection streams
439 - MEDIUM: quic-sock: fix udp source address for send on listener socket
440
Willy Tarreau40c88f92023-01-07 09:45:17 +01004412023/01/07 : 2.8-dev1
442 - MEDIUM: 51d: add support for 51Degrees V4 with Hash algorithm
443 - MINOR: debug: support pool filtering on "debug dev memstats"
444 - MINOR: debug: add a balance of alloc - free at the end of the memstats dump
445 - LICENSE: wurfl: clarify the dummy library license.
446 - MINOR: event_hdl: add event handler base api
447 - DOC/MINOR: api: add documentation for event_hdl feature
448 - MEDIUM: ssl: rename the struct "cert_key_and_chain" to "ckch_data"
449 - MINOR: quic: remove qc from quic_rx_packet
450 - MINOR: quic: complete traces in qc_rx_pkt_handle()
451 - MINOR: quic: extract datagram parsing code
452 - MINOR: tools: add port for ipcmp as optional criteria
453 - MINOR: quic: detect connection migration
454 - MINOR: quic: ignore address migration during handshake
455 - MINOR: quic: startup detect for quic-conn owned socket support
456 - MINOR: quic: test IP_PKTINFO support for quic-conn owned socket
457 - MINOR: quic: define config option for socket per conn
458 - MINOR: quic: allocate a socket per quic-conn
459 - MINOR: quic: use connection socket for emission
460 - MEDIUM: quic: use quic-conn socket for reception
461 - MEDIUM: quic: move receive out of FD handler to quic-conn io-cb
462 - MINOR: mux-quic: rename duplicate function names
463 - MEDIUM: quic: requeue datagrams received on wrong socket
464 - MINOR: quic: reconnect quic-conn socket on address migration
465 - MINOR: quic: activate socket per conn by default
466 - BUG/MINOR: ssl: initialize SSL error before parsing
467 - BUG/MINOR: ssl: initialize WolfSSL before parsing
468 - BUG/MINOR: quic: fix fd leak on startup check quic-conn owned socket
469 - BUG/MEDIIM: stconn: Flush output data before forwarding close to write side
470 - MINOR: server: add srv->rid (revision id) value
471 - MINOR: stats: add server revision id support
472 - MINOR: server/event_hdl: add support for SERVER_ADD and SERVER_DEL events
473 - MINOR: server/event_hdl: add support for SERVER_UP and SERVER_DOWN events
474 - BUG/MEDIUM: checks: do not reschedule a possibly running task on state change
475 - BUG/MINOR: checks: make sure fastinter is used even on forced transitions
476 - CLEANUP: assorted typo fixes in the code and comments
477 - MINOR: mworker: display an alert upon a wait-mode exit
478 - BUG/MEDIUM: mworker: fix segv in early failure of mworker mode with peers
479 - BUG/MEDIUM: mworker: create the mcli_reload socketpairs in case of upgrade
480 - BUG/MINOR: checks: restore legacy on-error fastinter behavior
481 - MINOR: check: use atomic for s->consecutive_errors
482 - MINOR: stats: properly handle ST_F_CHECK_DURATION metric
483 - MINOR: mworker: remove unused legacy code in mworker_cleanlisteners
484 - MINOR: peers: unused code path in process_peer_sync
485 - BUG/MINOR: init/threads: continue to limit default thread count to max per group
486 - CLEANUP: init: remove useless assignment of nbthread
487 - BUILD: atomic: atomic.h may need compiler.h on ARMv8.2-a
488 - BUILD: makefile/da: also clean Os/ in Device Atlas dummy lib dir
489 - BUG/MEDIUM: httpclient/lua: double LIST_DELETE on end of lua task
490 - CLEANUP: pools: move the write before free to the uaf-only function
491 - CLEANUP: pool: only include pool-os from pool.c not pool.h
492 - REORG: pool: move all the OS specific code to pool-os.h
493 - CLEANUP: pools: get rid of CONFIG_HAP_POOLS
494 - DEBUG: pool: show a few examples in -dMhelp
495 - MINOR: pools: make DEBUG_UAF a runtime setting
496 - BUG/MINOR: promex: create haproxy_backend_agg_server_status
497 - MINOR: promex: introduce haproxy_backend_agg_check_status
498 - DOC: promex: Add missing backend metrics
499 - BUG/MAJOR: fcgi: Fix uninitialized reserved bytes
500 - REGTESTS: fix the race conditions in iff.vtc
501 - CI: github: reintroduce openssl 1.1.1
502 - BUG/MINOR: quic: properly handle alloc failure in qc_new_conn()
503 - BUG/MINOR: quic: handle alloc failure on qc_new_conn() for owned socket
504 - CLEANUP: mux-quic: remove unused attribute on qcs_is_close_remote()
505 - BUG/MINOR: mux-quic: remove qcs from opening-list on free
506 - BUG/MINOR: mux-quic: handle properly alloc error in qcs_new()
507 - CI: github: split ssl lib selection based on git branch
508 - REGTESTS: startup: check maxconn computation
509 - BUG/MINOR: startup: don't use internal proxies to compute the maxconn
510 - REGTESTS: startup: change the expected maxconn to 11000
511 - CI: github: set ulimit -n to a greater value
512 - REGTESTS: startup: activate automatic_maxconn.vtc
513 - MINOR: sample: add param converter
514 - CLEANUP: ssl: remove check on srv->proxy
515 - BUG/MEDIUM: freq-ctr: Don't compute overshoot value for empty counters
516 - BUG/MEDIUM: resolvers: Use tick_first() to update the resolvers task timeout
517 - REGTESTS: startup: add alternatives values in automatic_maxconn.vtc
518 - BUG/MEDIUM: h3: reject request with invalid header name
519 - BUG/MEDIUM: h3: reject request with invalid pseudo header
520 - MINOR: http: extract content-length parsing from H2
521 - BUG/MEDIUM: h3: parse content-length and reject invalid messages
522 - CI: github: remove redundant ASAN loop
523 - CI: github: split matrix for development and stable branches
524 - BUG/MEDIUM: mux-h1: Don't release H1 stream upgraded from TCP on error
525 - BUG/MINOR: mux-h1: Fix test instead a BUG_ON() in h1_send_error()
526 - MINOR: http-htx: add BUG_ON to prevent API error on http_cookie_register
527 - BUG/MEDIUM: h3: fix cookie header parsing
528 - BUG/MINOR: h3: fix memleak on HEADERS parsing failure
529 - MINOR: h3: check return values of htx_add_* on headers parsing
530 - MINOR: ssl: Remove unneeded buffer allocation in show ocsp-response
531 - MINOR: ssl: Remove unnecessary alloc'ed trash chunk in show ocsp-response
532 - BUG/MINOR: ssl: Fix memory leak of find_chain in ssl_sock_load_cert_chain
533 - MINOR: stats: provide ctx for dumping functions
534 - MINOR: stats: introduce stats field ctx
535 - BUG/MINOR: stats: fix show stat json buffer limitation
536 - MINOR: stats: make show info json future-proof
537 - BUG/MINOR: quic: fix crash on PTO rearm if anti-amplification reset
538 - BUILD: 51d: fix build issue with recent compilers
539 - REGTESTS: startup: disable automatic_maxconn.vtc
540 - BUILD: peers: peers-t.h depends on stick-table-t.h
541 - BUG/MEDIUM: tests: use tmpdir to create UNIX socket
542 - BUG/MINOR: mux-h1: Report EOS on parsing/internal error for not running stream
543 - BUG/MINOR:: mux-h1: Never handle error at mux level for running connection
544 - BUG/MEDIUM: stats: Rely on a local trash buffer to dump the stats
545 - OPTIM: pool: split the read_mostly from read_write parts in pool_head
546 - MINOR: pool: make the thread-local hot cache size configurable
547 - MINOR: freq_ctr: add opportunistic versions of swrate_add()
548 - MINOR: pool: only use opportunistic versions of the swrate_add() functions
549 - REGTESTS: ssl: enable the ssl_reuse.vtc test for WolfSSL
550 - BUG/MEDIUM: mux-quic: fix double delete from qcc.opening_list
551 - BUG/MEDIUM: quic: properly take shards into account on bind lines
552 - BUG/MINOR: quic: do not allocate more rxbufs than necessary
553 - MINOR: ssl: Add a lock to the OCSP response tree
554 - MINOR: httpclient: Make the CLI flags public for future use
555 - MINOR: ssl: Add helper function that extracts an OCSP URI from a certificate
556 - MINOR: ssl: Add OCSP request helper function
557 - MINOR: ssl: Add helper function that checks the validity of an OCSP response
558 - MINOR: ssl: Add "update ssl ocsp-response" cli command
559 - MEDIUM: ssl: Add ocsp_certid in ckch structure and discard ocsp buffer early
560 - MINOR: ssl: Add ocsp_update_tree and helper functions
561 - MINOR: ssl: Add crt-list ocsp-update option
562 - MINOR: ssl: Store 'ocsp-update' mode in the ckch_data and check for inconsistencies
563 - MEDIUM: ssl: Insert ocsp responses in update tree when needed
564 - MEDIUM: ssl: Add ocsp update task main function
565 - MEDIUM: ssl: Start update task if at least one ocsp-update option is set to on
566 - DOC: ssl: Add documentation for ocsp-update option
567 - REGTESTS: ssl: Add tests for ocsp auto update mechanism
568 - MINOR: ssl: Move OCSP code to a dedicated source file
569 - BUG/MINOR: ssl/ocsp: check chunk_strcpy() in ssl_ocsp_get_uri_from_cert()
570 - CLEANUP: ssl/ocsp: add spaces around operators
571 - BUG/MEDIUM: mux-h2: Refuse interim responses with end-stream flag set
572 - BUG/MINOR: pool/stats: Use ullong to report total pool usage in bytes in stats
573 - BUG/MINOR: ssl/ocsp: httpclient blocked when doing a GET
574 - MINOR: httpclient: don't add body when istlen is empty
575 - MEDIUM: httpclient: change the default log format to skip duplicate proxy data
576 - BUG/MINOR: httpclient/log: free of invalid ptr with httpclient_log_format
577 - MEDIUM: mux-quic: implement shutw
578 - MINOR: mux-quic: do not count stream flow-control if already closed
579 - MINOR: mux-quic: handle RESET_STREAM reception
580 - MEDIUM: mux-quic: implement STOP_SENDING emission
581 - MINOR: h3: use stream error when needed instead of connection
582 - CI: github: enable github api authentication for OpenSSL tags read
583 - BUG/MINOR: mux-quic: ignore remote unidirectional stream close
584 - CI: github: use the GITHUB_TOKEN instead of a manually generated token
585 - BUILD: makefile: build the features list dynamically
586 - BUILD: makefile: move common options-oriented macros to include/make/options.mk
587 - BUILD: makefile: sort the features list
588 - BUILD: makefile: initialize all build options' variables at once
589 - BUILD: makefile: add a function to collect all options' CFLAGS/LDFLAGS
590 - BUILD: makefile: start to automatically collect CFLAGS/LDFLAGS
591 - BUILD: makefile: ensure that all USE_* handlers appear before CFLAGS are used
592 - BUILD: makefile: clean the wolfssl include and lib generation rules
593 - BUILD: makefile: make sure to also ignore SSL_INC when using wolfssl
594 - BUILD: makefile: reference libdl only once
595 - BUILD: makefile: make sure LUA_INC and LUA_LIB are always initialized
596 - BUILD: makefile: do not restrict Lua's prepend path to empty LUA_LIB_NAME
597 - BUILD: makefile: never force -latomic, set USE_LIBATOMIC instead
598 - BUILD: makefile: add an implicit USE_MATH variable for -lm
599 - BUILD: makefile: properly report USE_PCRE/USE_PCRE2 in features
600 - CLEANUP: makefile: properly indent ifeq/ifneq conditional blocks
601 - BUILD: makefile: rework 51D to split v3/v4
602 - BUILD: makefile: support LIBCRYPT_LDFLAGS
603 - BUILD: makefile: support RT_LDFLAGS
604 - BUILD: makefile: support THREAD_LDFLAGS
605 - BUILD: makefile: support BACKTRACE_LDFLAGS
606 - BUILD: makefile: support SYSTEMD_LDFLAGS
607 - BUILD: makefile: support ZLIB_CFLAGS and ZLIB_LDFLAGS
608 - BUILD: makefile: support ENGINE_CFLAGS
609 - BUILD: makefile: support OPENSSL_CFLAGS and OPENSSL_LDFLAGS
610 - BUILD: makefile: support WOLFSSL_CFLAGS and WOLFSSL_LDFLAGS
611 - BUILD: makefile: support LUA_CFLAGS and LUA_LDFLAGS
612 - BUILD: makefile: support DEVICEATLAS_CFLAGS and DEVICEATLAS_LDFLAGS
613 - BUILD: makefile: support PCRE[2]_CFLAGS and PCRE[2]_LDFLAGS
614 - BUILD: makefile: refactor support for 51DEGREES v3/v4
615 - BUILD: makefile: support WURFL_CFLAGS and WURFL_LDFLAGS
616 - BUILD: makefile: make all OpenSSL variants use the same settings
617 - BUILD: makefile: remove the special case of the SSL option
618 - BUILD: makefile: only consider settings from enabled options
619 - BUILD: makefile: also list per-option settings in 'make opts'
620 - BUG/MINOR: debug: don't mask the TH_FL_STUCK flag before dumping threads
621 - MINOR: cfgparse-ssl: avoid a possible crash on OOM in ssl_bind_parse_npn()
622 - BUG/MINOR: ssl: Missing goto in error path in ocsp update code
623 - BUG/MINOR: stick-table: report the correct action name in error message
624 - CI: Improve headline in matrix.py
625 - CI: Add in-memory cache for the latest OpenSSL/LibreSSL
626 - CI: Use proper `if` blocks instead of conditional expressions in matrix.py
627 - CI: Unify the `GITHUB_TOKEN` name across matrix.py and vtest.yml
628 - CI: Explicitly check environment variable against `None` in matrix.py
629 - CI: Reformat `matrix.py` using `black`
630 - MINOR: config: add environment variables for default log format
631 - REGTESTS: Remove REQUIRE_VERSION=1.9 from all tests
632 - REGTESTS: Remove REQUIRE_VERSION=2.0 from all tests
633 - REGTESTS: Remove tests with REQUIRE_VERSION_BELOW=1.9
634 - BUG/MINOR: http-fetch: Only fill txn status during prefetch if not already set
635 - BUG/MAJOR: buf: Fix copy of wrapping output data when a buffer is realigned
636 - DOC: config: fix alphabetical ordering of http-after-response rules
637 - MINOR: http-rules: Add missing actions in http-after-response ruleset
638 - DOC: config: remove duplicated "http-response sc-set-gpt0" directive
639 - BUG/MINOR: proxy: free orgto_hdr_name in free_proxy()
640 - REGTEST: fix the race conditions in json_query.vtc
641 - REGTEST: fix the race conditions in add_item.vtc
642 - REGTEST: fix the race conditions in digest.vtc
643 - REGTEST: fix the race conditions in hmac.vtc
644 - BUG/MINOR: fd: avoid bad tgid assertion in fd_delete() from deinit()
645 - BUG/MINOR: http: Memory leak of http redirect rules' format string
646 - MEDIUM: stick-table: set the track-sc limit at boottime via tune.stick-counters
647 - MINOR: stick-table: implement the sc-add-gpc() action
648
Willy Tarreaueaded982022-12-01 15:25:34 +01006492022/12/01 : 2.8-dev0
650 - MINOR: version: mention that it's development again
651
Willy Tarreau437fd282022-12-01 15:16:46 +01006522022/12/01 : 2.7.0
653 - MINOR: ssl: forgotten newline in error messages on ca-file
654 - BUG/MINOR: ssl: shut the ca-file errors emitted during httpclient init
655 - DOC: config: provide some configuration hints for "http-reuse"
656 - DOC: config: refer to section about quoting in the "add_item" converter
657 - DOC: halog: explain how to use -ac and -ad in the help message
658 - DOC: config: clarify the fact that SNI should not be used in HTTP scenarios
659 - DOC: config: mention that a single monitor-uri rule is supported
660 - DOC: config: explain how default matching method for ACL works
661 - DOC: config: clarify the fact that "retries" is not just for connections
662 - BUILD: halog: fix missing double-quote at end of help line
663 - DOC: config: clarify the -m dir and -m dom pattern matching methods
664 - MINOR: activity: report uptime in "show activity"
665 - REORG: activity/cli: move the "show activity" handler to activity.c
666 - DEV: poll: add support for epoll
667 - DEV: tcploop: centralize the polling code into wait_for_fd()
668 - DEV: tcploop: add support for POLLRDHUP when supported
669 - DEV: tcploop: do not report an error on POLLERR
670 - DEV: tcploop: add optional support for epoll
671 - SCRIPTS: announce-release: add a link to the data plane API
672 - CLEANUP: stick-table: fill alignment holes in the stktable struct
673 - MINOR: stick-table: store a per-table hash seed and use it
674 - MINOR: stick-table: show the shard number in each entry's "show table" output
675 - CLEANUP: ncbuf: remove ncb_blk args by value
676 - CLEANUP: ncbuf: inline small functions
677 - CLEANUP: ncbuf: use standard BUG_ON with DEBUG_STRICT
678 - BUG/MINOR: quic: Endless loop during retransmissions
679 - MINOR: mux-h2: add the expire task and its expiration date in "show fd"
680 - BUG/MINOR: peers: always initialize the stksess shard value
681 - REGTESTS: fix peers-related regtests regarding "show table"
682 - BUG/MEDIUM: mux-h1: Close client H1C on EOS when there is no output data
683 - MINOR: stick-table: change the API of the function used to calculate the shard
684 - CLEANUP: peers: factor out the key len calculation in received updates
685 - BUG/MINOR: peers: always update the stksess shard number on incoming updates
686 - CLEANUP: assorted typo fixes in the code and comments
687 - MINOR: mux-h1: add the expire task and its expiration date in "show fd"
688 - MINOR: debug: improve error handling on the memstats command parser
689 - BUILD: quic: allow build with USE_QUIC and USE_OPENSSL_WOLFSSL
690 - CLEANUP: anon: clarify the help message on "debug dev hash"
691 - MINOR: debug: relax access restrictions on "debug dev hash" and "memstats"
692 - SCRIPTS: run-regtests: add a version check
693 - MINOR: version: mention that it's stable now
694
Willy Tarreau0279df92022-11-24 17:13:05 +01006952022/11/24 : 2.7-dev10
696 - MEDIUM: tcp-act: add parameter rst-ttl to silent-drop
697 - BUG/MAJOR: quic: Crash upon retransmission of dgrams with several packets
698 - MINOR: cli: print parsed command when not found
699 - BUG/MAJOR: quic: Crash after discarding packet number spaces
700 - CLEANUP: quic: replace "choosen" with "chosen" all over the code
701 - MINOR: cli/pools: store "show pools" results into a temporary array
702 - MINOR: cli/pools: add sorting capabilities to "show pools"
703 - MINOR: cli/pools: add pool name filtering capability to "show pools"
704 - DOC: configuration: fix quic prefix typo
705 - MINOR: quic: report error if force-retry without cluster-secret
706 - MINOR: global: generate random cluster.secret if not defined
707 - BUG/MINOR: resolvers: do not run the timeout task when there's no resolution
708 - BUG/MINOR: server/idle: at least use atomic stores when updating max_used_conns
709 - MINOR: server/idle: make the next_takeover index per-tgroup
710 - BUILD: listener: fix build warning on global_listener_rwlock without threads
711 - BUG/MAJOR: sched: protect task during removal from wait queue
712 - BUILD: sched: fix build with DEBUG_THREAD with the previous commit
713 - DOC: quic: add note on performance issue with listener contention
714 - BUG/MINOR: cfgparse-listen: fix ebpt_next_dup pointer dereference on proxy "from" inheritance
715 - BUG/MINOR: log: fix parse_log_message rfc5424 size check
716 - CLEANUP: arg: remove extra check in make_arg_list arg escaping
717 - CLEANUP: tools: extra check in utoa_pad
718 - MINOR: h1: Consider empty port as invalid in authority for CONNECT
719 - MINOR: http: Considere empty ports as valid default ports
720 - BUG/MINOR: http-htx: Normalized absolute URIs with an empty port
721 - BUG/MINOR: h1: Replace authority validation to conform RFC3986
722 - REG-TESTS: http: Add more tests about authority/host matching
723 - BUG/MINOR: http-htx: Don't consider an URI as normalized after a set-uri action
724 - BUG/MEDIUM: mux-h1: Don't release H1C on timeout if there is a SC attached
725 - BUG/MEDIUM: mux-h1: Subscribe for reads on error on sending path
726 - BUILD: http-htx: Silent build error about a possible NULL start-line
727 - DOC: configuration.txt: add default_value for table_idle signature
728 - BUILD: ssl-sock: Silent error about NULL deref in ssl_sock_bind_verifycbk()
729 - BUG/MEDIUM: mux-h1: Remove H1C_F_WAIT_NEXT_REQ flag on a next request
730 - BUG/MINOR: mux-h1: Fix handling of 408-Request-Time-Out
731 - MINOR: mux-h1: Remove H1C_F_WAIT_NEXT_REQ in functions handling errors
732 - MINOR: mux-h1: Avoid useless call to h1_send() if no error is sent
733 - DOC: configuration.txt: fix typo in table_idle signature
734 - BUILD: stick-tables: fix build breakage in xxhash on older compilers
735 - BUILD: compiler: include compiler's definitions before ours
736 - BUILD: quic: global.h is needed in cfgparse-quic
737 - CLEANUP: tools: do not needlessly include xxhash nor cli from tools.h
738 - BUILD: flags: really restrict the cases where flags are exposed
739 - BUILD: makefile: minor reordering of objects by build time
740 - BUILD: quic: silence two invalid build warnings at -O1 with gcc-6.5
741 - BUILD: quic: use openssl-compat.h instead of openssl/ssl.h
742 - MEDIUM: ssl: add minimal WolfSSL support with OpenSSL compatibility mode
743 - MINOR: sample: make the rand() sample fetch function use the statistical_prng
744 - MINOR: auth: silence null dereference warning in check_user()
745 - CLEANUP: peers: fix format string for status messages (int signedness)
746 - CLEANUP: qpack: fix format string in debugging code (int signedness)
747 - CLEANUP: qpack: properly use the QPACK macros not HPACK ones in debug code
748 - BUG/MEDIUM: quic: fix datagram dropping on queueing failed
749
Willy Tarreaua0abec82022-11-18 17:48:49 +01007502022/11/18 : 2.7-dev9
751 - BUILD: quic: QUIC mux build fix for 32-bit build
752 - BUILD: scripts: disable tests build on QuicTLS build
753 - BUG/MEDIUM: httpclient: segfault when the httpclient parser fails
754 - BUILD: ssl_sock: fix null dereference for QUIC build
755 - BUILD: quic: Fix build for m68k cross-compilation
756 - BUG/MINOR: quic: fix buffer overflow on retry token generation
757 - MINOR: quic: add version field on quic_rx_packet
758 - MINOR: quic: extend pn_offset field from quic_rx_packet
759 - MINOR: quic: define first packet flag
760 - MINOR: quic: extract connection retrieval
761 - MINOR: quic: split and rename qc_lstnr_pkt_rcv()
762 - MINOR: quic: refactor packet drop on reception
763 - MINOR: quic: extend Retry token check function
764 - BUG/MINOR: log: Preserve message facility when the log target is a ring buffer
765 - BUG/MINOR: ring: Properly parse connect timeout
766 - BUG/MEDIUM: httpclient/lua: crash when the lua task timeout before the httpclient
767 - BUG/MEDIUM: httpclient: check if the httpclient was released in the IO handler
768 - REGTESTS: httpclient/lua: test the lua task timeout with the httpclient
769 - CI: github: dump the backtrace of coredumps in the alpine container
770 - BUILD: Makefile: add "USE_SHM_OPEN" on the linux-musl target
771 - DOC: lua: add a note about compression w/ httpclient
772 - CLEANUP: mworker/cli: rename the status function to loadstatus
773 - MINOR: mworker/cli: does no try to dump the startup-logs w/o USE_SHM_OPEN
774 - MINOR: list: fixing typo in MT_LIST_LOCK_ELT
775 - DOC/MINOR: list: fixing MT_LIST_LOCK_ELT macro documentation
776 - MINOR: list: adding MT_LIST_APPEND_LOCKED macro
777 - BUG/MINOR: mux-quic: complete flow-control for uni streams
778 - BUG/MEDIUM: compression: handle rewrite errors when updating response headers
779 - MINOR: quic: do not crash on unhandled sendto error
780 - MINOR: quic: display unknown error sendto counter on stat page
781 - MINOR: peers: Support for peer shards
782 - MINOR: peers: handle multiple resync requests using shards
783 - BUG/MINOR: sink: Only use backend capability for the sink proxies
784 - BUG/MINOR: sink: Set default connect/server timeout for implicit ring buffers
785 - MINOR: ssl: add the SSL error string when failing to load a certificate
786 - MINOR: ssl: add the SSL error string before the chain
787 - MEDIUM: ssl: be stricter about chain error
788 - BUG/MAJOR: stick-table: don't process store-response rules for applets
789 - MINOR: quic: remove unnecessary quic_session_accept()
790 - BUG/MINOR: quic: fix subscribe operation
791 - BUG/MINOR: log: fixing bug in tcp syslog_io_handler Octet-Counting
792 - MINOR: ssl: dump the SSL string error when SSL_CTX_use_PrivateKey() failed.
793 - MINOR: quic: add counter for interrupted reception
794 - BUG/MINOR: quic: fix race condition on datagram purging
795 - CI: add monthly gcc cross compile jobs
796 - CLEANUP: assorted typo fixes in the code and comments
797 - CLEANUP: ssl: remove dead code in ssl_sock_load_pem_into_ckch()
798 - BUG/MINOR: httpclient: fixed memory allocation for the SSL ca_file
799 - BUG/MINOR: ssl: Memory leak of DH BIGNUM fields
800 - BUG/MINOR: ssl: Memory leak of AUTHORITY_KEYID struct when loading issuer
801 - BUG/MINOR: ssl: ocsp structure not freed properly in case of error
802 - CI: switch to the "latest" LibreSSL
803 - CI: enable QUIC for LibreSSL builds
804 - BUG/MEDIUM: ssl: Verify error codes can exceed 63
805 - MEDIUM: ssl: {ca,crt}-ignore-err can now use error constant name
806 - MINOR: ssl: x509_v_err_str converter transforms an integer to a X509_V_ERR name
807 - CLEANUP: cli: rename dynamic error printing state
808 - MINOR: cli: define usermsgs print context
809 - MINOR: server: clear prefix on stderr logs after add server
810 - BUG/MINOR: ssl: bind_conf is uncorrectly accessed when using QUIC
811 - BUILD: ssl_utils: fix build on gcc versions before 8
812 - BUILD: debug: remove unnecessary quotes in HA_WEAK() calls
813 - CI: emit the compiler's version in the build reports
814 - IMPORT: xxhash: update xxHash to version 0.8.1
815 - IMPORT: slz: declare len to fix debug build when optimal match is enabled
816 - IMPORT: slz: mention the potential header in slz_finish()
817 - IMPORT: slz: define and use a __fallthrough statement for switch/case
818 - BUILD: compiler: add a macro to detect if another one is set and equals 1
819 - BUILD: compiler: add a default definition for __has_attribute()
820 - BUILD: compiler: define a __fallthrough statement for switch/case
821 - BUILD: sample: use __fallthrough in smp_is_rw() and smp_dup()
822 - BUILD: quic: use __fallthrough in quic_connect_server()
823 - BUILD: ssl/crt-list: use __fallthrough in cli_io_handler_add_crtlist()
824 - BUILD: ssl: use __fallthrough in cli_io_handler_commit_{cert,cafile_crlfile}()
825 - BUILD: ssl: use __fallthrough in cli_io_handler_tlskeys_files()
826 - BUILD: hlua: use __fallthrough in hlua_post_init_state()
827 - BUILD: stream: use __fallthrough in stats_dump_full_strm_to_buffer()
828 - BUILD: tcpcheck: use __fallthrough in check_proxy_tcpcheck()
829 - BUILD: stats: use __fallthrough in stats_dump_proxy_to_buffer()
830 - BUILD: peers: use __fallthrough in peer_io_handler()
831 - BUILD: hash: use __fallthrough in hash_djb2()
832 - BUILD: tools: use __fallthrough in url_decode()
833 - BUILD: args: use __fallthrough in make_arg_list()
834 - BUILD: acl: use __fallthrough in parse_acl_expr()
835 - BUILD: spoe: use __fallthrough in spoe_handle_appctx()
836 - BUILD: logs: use __fallthrough in build_log_header()
837 - BUILD: check: use __fallthrough in __health_adjust()
838 - BUILD: http_act: use __fallthrough in parse_http_del_header()
839 - BUILD: h1_htx: use __fallthrough in h1_parse_chunk()
840 - BUILD: vars: use __fallthrough in var_accounting_{diff,add}()
841 - BUILD: map: use __fallthrough in cli_io_handler_*()
842 - BUILD: compression: use __fallthrough in comp_http_payload()
843 - BUILD: stconn: use __fallthrough in various shutw() functions
844 - BUILD: prometheus: use __fallthrough in promex_dump_metrics() and IO handler()
845 - CLEANUP: ssl: remove printf in bind_parse_ignore_err
846 - BUG/MINOR: ssl: crt-ignore-err memory leak with 'all' parameter
847 - BUG/MINOR: ssl: Fix potential overflow
848 - CLEANUP: stick-table: remove the unused table->exp_next
849 - OPTIM: stick-table: avoid atomic ops in stktable_requeue_exp() when possible
850 - BUG/MEDIUM: stick-table: fix a race condition when updating the expiration task
851 - MEDIUM: http-ana: remove set-cookie2 support
852 - BUG/MEDIUM: wdt/clock: properly handle early task hangs
853 - MINOR: deinit: add a "quick-exit" option to bypass the deinit step
854 - OPTIM: ebtree: make ebmb_insert_prefix() keep a copy the new node's pfx
855 - OPTIM: ebtree: make ebmb_insert_prefix() keep a copy the new node's key
856 - MINOR: ssl: ssl_sock_load_cert_chain() display error strings
857 - MINOR: ssl: reintroduce ERR_GET_LIB(ret) == ERR_LIB_PEM in ssl_sock_load_pem_into_ckch()
858 - BUG/MINOR: http-htx: Fix error handling during parsing http replies
859 - BUG/MINOR: resolvers: Don't wait periodic resolution on healthcheck failure
860 - BUG/MINOR: resolvers: Set port before IP address when processing SRV records
861 - BUG/MINOR: mux-fcgi: Be sure to send empty STDING record in case of zero-copy
862 - BUG/MEDIUM: mux-fcgi: Avoid value length overflow when it doesn't fit at once
863 - BUG/MINOR: ssl: SSL_load_error_strings might not be defined
864 - MINOR: pool/debug: create a new pool_alloc_flag() macro
865 - MINOR: dynbuf: switch allocation and release to macros to better track users
866 - BUG/MINOR: mux-h1: Do not send a last null chunk on body-less answers
867 - REG-TESTS: cache: Remove T-E header for 304-Not-Modified responses
868 - DOC: config: fix alphabetical ordering of global section
869 - MINOR: trace: split the CLI "trace" parser in CLI vs statement
870 - MEDIUM: trace: create a new "trace" statement in the "global" section
871 - BUG/MEDIUM: ring: fix creation of server in uninitialized ring
872 - BUILD: quic: fix dubious 0-byte overflow on qc_release_lost_pkts
873 - BUILD: makefile: mark poll and tcploop targets as phony
874 - BUILD: makefile: properly pass CC to sub-projects
875 - BUILD: makefile: move default verbosity settings to include/make/verbose.mk
876 - BUILD: makefile: use $(cmd_MAKE) in quiet mode
877 - BUILD: makefile: move the compiler option detection stuff to compiler.mk
878 - DEV: poll: make the connect() step an action as well
879 - DEV: poll: strip the "do_" prefix from reported function names
880 - DEV: poll: indicate the FD's side in front of its value
881 - BUG/MINOR: pool/cli: use ullong to report total pool usage in bytes
882 - MINOR: mux-h1: Remove usless code inside shutr callback
883 - CLEANUP: mux-h1; Rename H1S_F_ERROR flag into H1S_F_ERROR_MASK
884 - REORG: mux-h1: Reorg the H1C structure
885 - CLEANUP: mux-h1: Rename H1C_F_ST_ERROR and H1C_F_ST_SILENT_SHUT flags
886 - MINOR: mux-h1: Add a dedicated enum to deal with H1 connection state
887 - MEDIUM: mux-h1: Handle H1C states via its state field instead of H1C_F_ST_*
888 - MINOR: mux-h1: Don't handle subscribe for reads in h1_process_demux()
889 - CLEANUP: mux-h1: Rename H1C_F_ERR_PENDING into H1C_F_ABRT_PENDING
890 - MINOR: mux-h1: Add flag on H1 stream to deal with internal errors
891 - MEDIUM: mux-h1: Rely on the H1C to deal with shutdown for reads
892 - CLEANUP: mux-h1: Reorder H1 connection flags to avoid holes
893 - MEDIUM: mux-h1: Don't report a final error whe a message is aborted
894 - MEDIUM: mux-pt: Don't always set a final error on SE on the sending path
895 - MEDIUM: mux-h2: Introduce flags to deal with connection read/write errors
896 - CLEANUP: mux-h2: Remove unused fields in h2c structures
897 - MEDIUM: mux-fcgi: Introduce flags to deal with connection read/write errors
898 - MINOR: sconn: Set SE_FL_ERROR only when there is no more data to read
899 - MINOR: mux-h1: Rely on a H1S flag to know a WS key was found or not
900 - DOC: lua-api: Remove warning about the lua filters
901 - BUG/MEDIUM: listener: Fix race condition when updating the global mngmt task
902 - CLEANUP: listener: Remove useless task_queue from manage_global_listener_queue
903 - BUG/MINOR: mux-h1: Fix error handling when H1S allocation failed on client side
904 - DOC: internal: commit notes about polling states and flags
905 - DOC: internal: commit notes about polling states and flags on connect()
906 - CLEANUP: mux-h1: Don't test h1c in h1_shutw_conn()
907 - BUG/MINOR: http_ana/txn: don't re-initialize txn and req var lists
908 - BUG/MEDIUM: raw-sock: Don't report connection error if something was received
909 - BUG/MINOR: ssl: don't initialize the keylog callback when not required
910 - BUILD: Makefile: enable USE_SHM_OPEN by default on freebsd
911 - BUG/MEDIUM: peers: messages about unkown tables not correctly ignored
912 - MINOR: cfgparse: Always check the section position
913 - MEDIUM: thread: Restric nbthread/thread-group(s) to very first global sections
914 - BUILD: peers: Remove unused variables
915 - MINOR: ncbuf: complete doc for ncb_advance()
916 - BUG/MEDIUM: quic: fix unsuccessful handshakes on ncb_advance error
917 - BUG/MEDIUM: quic: fix memleak for out-of-order crypto data
918 - MINOR: quic: complete traces/debug for handshake
919
Willy Tarreauea8aebe2022-10-14 20:45:23 +02009202022/10/14 : 2.7-dev8
921 - BUG/MINOR: checks: update pgsql regex on auth packet
922 - DOC: config: Fix pgsql-check documentation to make user param mandatory
923 - CLEANUP: mux-quic: remove usage of non-standard ull type
924 - CLEANUP: quic: remove global var definition in quic_tls header
925 - BUG/MINOR: quic: adjust quic_tls prototypes
926 - CLEANUP: quic: fix headers
927 - CLEANUP: quic: remove unused function prototype
928 - CLEANUP: quic: remove duplicated varint code from xprt_quic.h
929 - CLEANUP: quic: create a dedicated quic_conn module
930 - BUG/MINOR: mux-quic: ignore STOP_SENDING for locally closed stream
931 - BUG/MEDIUM: lua: Don't crash in hlua_lua2arg_check on failure
932 - BUG/MEDIUM: lua: handle stick table implicit arguments right.
933 - BUILD: h1: silence an initiialized warning with gcc-4.7 and -Os
934 - MINOR: fd: add a new function to only raise RLIMIT_NOFILE
935 - MINOR: init: do not try to shrink existing RLIMIT_NOFIlE
936 - BUG/MINOR: http-fetch: Update method after a prefetch in smp_fetch_meth()
937 - BUILD: http_fetch: silence an uninitiialized warning with gcc-4/5/6 at -Os
938 - BUG/MINOR: hlua: hlua_channel_insert_data() behavior conflicts with documentation
939 - MINOR: quic: limit usage of ssl_sock_ctx in favor of quic_conn
940 - MINOR: mux-quic: check quic-conn return code on Tx
941 - CLEANUP: quic: fix indentation
942 - MEDIUM: quic: retrieve frontend destination address
943 - CLEANUP: Reapply ist.cocci (2)
944 - CLEANUP: Reapply strcmp.cocci
945 - CLEANUP: quic/receiver: remove the now unused tx_qring list
946 - BUG/MINOR: quic: set IP_PKTINFO socket option for QUIC receivers only
947 - MINOR: hlua: some luaL_checktype() calls were not guarded with MAY_LJMP
948 - DOC: configuration: missing 'if' in tcp-request content example
949 - MINOR: hlua: removing ambiguous lua_pushvalue with 0 index
950 - BUG/MAJOR: stick-tables: do not try to index a server name for applets
951 - MINOR: plock: support disabling exponential back-off
952 - MINOR: freq_ctr: use the thread's local time whenever possible
953 - MEDIUM: stick-table: switch the table lock to rwlock
954 - MINOR: stick-table: do not take an exclusive lock when downing ref_cnt
955 - MINOR: stick-table: move the write lock inside stktable_touch_with_exp()
956 - MEDIUM: stick-table: only take the lock when needed in stktable_touch_with_exp()
957 - MEDIUM: stick-table: make stksess_kill_if_expired() avoid the exclusive lock
958 - MEDIUM: stick-table: return inserted entry in __stktable_store()
959 - MEDIUM: stick-table: free newly allocated stkess if it couldn't be inserted
960 - MEDIUM: stick-table: switch to rdlock in stktable_lookup() and lookup_key()
961 - MEDIUM: stick-table: make stktable_get_entry() look up under a read lock
962 - MEDIUM: stick-table: do not take a lock to update t->current anymore.
963 - MEDIUM: stick-table: make stktable_set_entry() look up under a read lock
964 - MEDIUM: stick-table: requeue the expiration task out of the exclusive lock
965 - MINOR: stick-table: split stktable_store() between key and requeue
966 - MEDIUM: stick-table: always use atomic ops to requeue the table's task
967 - MEDIUM: stick-table: requeue the wakeup task out of the write lock
968 - BUG/MINOR: stick-table: fix build with DEBUG_THREAD
969 - REORG: mux-fcgi: Extract flags and enums into mux_fcgi-t.h
970 - MINOR: flags/mux-fcgi: Decode FCGI connection and stream flags
971 - BUG/MEDIUM: mux-h1: Add connection error handling when reading/sending on a pipe
972 - BUG/MEDIUM: mux-h1: Handle abort with an incomplete message during parsing
973 - BUG/MINOR: server: make sure "show servers state" hides private bits
974 - MINOR: checks: use the lighter PRNG for spread checks
975 - MEDIUM: checks: spread the checks load over random threads
976 - CI: SSL: use proper version generating when "latest" semantic is used
977 - CI: SSL: temporarily stick to LibreSSL=3.5.3
978 - MINOR: quic: New quic_cstream object implementation
979 - MINOR: quic: Extract CRYPTO frame parsing from qc_parse_pkt_frms()
980 - MINOR: quic: Use a non-contiguous buffer for RX CRYPTO data
981 - BUG/MINOR: quic: Stalled 0RTT connections with big ClientHello TLS message
982 - MINOR: quic: Split the secrets key allocation in two parts
983 - CLEANUP: quic: remove unused rxbufs member in receiver
984 - CLEANUP: quic: improve naming for rxbuf/datagrams handling
985 - MINOR: quic: implement datagram cleanup for quic_receiver_buf
986 - MINOR: ring: ring_cast_from_area() cast from an allocated area
987 - MINOR: buffers: split b_force_xfer() into b_cpy() and b_force_xfer()
988 - MINOR: logs: startup-logs can use a shm for logging the reload
989 - MINOR: mworker/cli: reload command displays the startup-logs
990 - MEDIUM: quic: respect the threads assigned to a bind line
991 - DOC: management: update the "reload" command of the master CLI
992 - BUILD: ssl_sock: bind_conf uninitialized in ssl_sock_bind_verifycbk()
993 - BUG/MEDIUM: httpclient: Don't set EOM flag on an empty HTX message
994 - MINOR: httpclient/lua: Don't set req_payload callback if body is empty
995 - DOC/CLEANUP: lua-api: some minor corrections
996 - DOC: lua-api: updating toolbox link
997 - DOC/CLEANUP: lua-api: removing duplicate core.proxies attribute
998 - DOC: management: add forgotten "show startup-logs"
999 - DOC: management: "show startup-logs" for master CLI
1000 - CI: Replace the deprecated `::set-output` command by writing to $GITHUB_OUTPUT in matrix.py
1001 - CI: Replace the deprecated `::set-output` command by writing to $GITHUB_OUTPUT in workflow definition
1002
Willy Tarreaudd4a2a62022-10-03 15:20:38 +020010032022/10/03 : 2.7-dev7
1004 - BUG/MEDIUM: mux-quic: fix nb_hreq decrement
1005 - CLEANUP: httpclient: deleted unused variables
1006 - MINOR: httpclient: enabled the use of SNI presets
1007 - OPTIM: hpack-huff: reduce the cache footprint of the huffman decoder
1008 - BUG/MINOR: mux-quic: do not keep detached qcs with empty Tx buffers
1009 - REORG: mux-quic: extract traces in a dedicated source file
1010 - REORG: mux-quic: export HTTP related function in a dedicated file
1011 - MINOR: mux-quic: refactor snd_buf
1012 - BUG/MEDIUM: mux-quic: properly trim HTX buffer on snd_buf reset
1013 - BUG/MINOR: mux-h1: Account consumed output data on synchronous connection error
1014 - BUG/MINOR: log: improper behavior when escaping log data
1015 - CLEANUP: tools: removing escape_chunk() function
1016 - MINOR: clock: split local and global date updates
1017 - MINOR: pollers: only update the local date during busy polling
1018 - MINOR: clock: do not update the global date too often
1019 - REGTESTS: 4be_1srv_smtpchk_httpchk_layer47errors: Return valid SMTP replies
1020 - MINOR: smtpchk: Update expect rule to fully match replies to EHLO commands
1021 - BUG/MINOR: smtpchk: SMTP Service check should gracefully close SMTP transaction
1022 - MINOR: list: documenting mt_list_for_each_entry_safe() macro
1023 - CLEANUP: list: Fix mt_list_for_each_entry_safe indentation
1024 - BUG/MINOR: hlua: Remove \n in Lua error message built with memprintf
1025 - MINOR: hlua: Allow argument on lua-lod(-per-thread) directives
1026 - BUG/MINOR: anon: memory illegal accesses in tools.c with hash_anon and hash_ipanon
1027 - MEDIUM: mworker/cli: keep the connection of the FD that ask for a reload
1028 - BUG/MINOR: hlua: fixing ambiguous sizeof in hlua_load_per_thread
1029 - MINOR: mworker/cli: replace close() by fd_delete()
1030 - MINOR: mworker: store and shows loading status
1031 - MINOR: mworker: mworker_cli_proxy_new_listener() returns a bind_conf
1032 - MINOR: mworker: stores the mcli_reload bind_conf
1033 - MINOR: mworker/cli: the mcli_reload bind_conf only send the reload status
1034 - DOC: management: describe the new reload command behavior
1035 - CLEANUP: list: fix again some style issues in the recent comments
1036 - BUG/MINOR: stream: Perform errors handling in right order in stream_new()
1037 - BUG/MEDIUM: stconn: Reset SE descriptor when we fail to create a stream
1038 - BUG/MEDIUM: resolvers: Remove aborted resolutions from query_ids tree
1039 - DOC: management: add timeout on the "reload" command
1040 - BUG/MINOR: ring: fix the size check in ring_make_from_area()
1041 - BUG/MINOR: config: don't count trailing spaces as empty arg
1042 - Revert "BUG/MINOR: config: don't count trailing spaces as empty arg"
1043 - BUG/MINOR: hlua: fixing hlua_http_msg_del_data behavior
1044 - BUG/MINOR: hlua: fixing hlua_http_msg_insert_data behavior
1045 - MINOR: cli: Add anonymization on a missed element for 'show sess all'
1046 - MINOR: cli: remove error message with 'set anon on|off'
1047 - MINOR: tools: modify hash_ipanon in order to use it in cli
1048 - MINOR: cli: use hash_ipanon to anonymized address
1049 - MINOR: cli: Add an anonymization on a missed element in 'show server state'
1050 - MINOR: config: correct errors about argument number in condition in cfgparse.c
1051 - MINOR: config: Add other keywords when dump the anonymized configuration file
1052 - MINOR: config: Add option line when the configuration file is dumped
1053 - MINOR: cli: correct commentary and replace 'set global-key' name
1054 - MINOR: tools: Impprove hash_ipanon to support dgram sockets and port offsets
1055 - MINOR: tools: Impprove hash_ipanon to not hash FD-based addresses
1056 - BUG/MINOR: hlua: _hlua_http_msg_delete incorrect behavior when offset is used
1057 - DOC: management: httpclient can resolve server names in URLs
1058 - BUG/MINOR: hlua: prevent crash when loading numerous arguments using lua-load(per-thread)
1059 - DOC/CLEANUP: lua-api: removing duplicate date functions doc
1060 - MINOR: hlua: ambiguous lua_pushvalue with 0 index
1061 - BUG/MINOR: config: don't count trailing spaces as empty arg (v2)
1062 - BUG/MEDIUM: config: count line arguments without dereferencing the output
1063 - BUG/MAJOR: conn-idle: fix hash indexing issues on idle conns
1064 - BUG/MINOR: config: insufficient syntax check of the global "maxconn" value
1065 - BUG/MINOR: backend: only enforce turn-around state when not redispatching
1066
Willy Tarreau4b10a5c2022-09-17 12:24:53 +020010672022/09/17 : 2.7-dev6
1068 - MINOR: Revert part of clarifying samples support per os commit
1069 - BUILD: makefile: enable crypt(3) for NetBSD
1070 - BUG/MINOR: quic: Retransmitted frames marked as acknowledged
1071 - BUG/MINOR: quic: Possible crash with "tls-ticket-keys" on QUIC bind lines
1072 - MINOR: http-check: Remove support for headers/body in "option httpchk" version
1073 - BUG/MINOR: h1: Support headers case adjustment for TCP proxies
1074 - BUG/MINOR: quic: Possible crash when verifying certificates
1075 - BUILD: quic: add some ifdef around the SSL_ERROR_* for libressl
1076 - BUILD: ssl: fix ssl_sock_switchtx_cbk when no client_hello_cb
1077 - BUILD: quic: temporarly ignore chacha20_poly1305 for libressl
1078 - BUILD: quic: enable early data only with >= openssl 1.1.1
1079 - BUILD: ssl: fix the ifdef mess in ssl_sock_initial_ctx
1080 - BUILD: quic: fix the #ifdef in ssl_quic_initial_ctx()
1081 - MINOR: quic: add QUIC support when no client_hello_cb
1082 - MINOR: quic: Add traces about sent or resent TX frames
1083 - MINOR: quic: No TRACE_LEAVE() in retrieve_qc_conn_from_cid()
1084 - BUG/MINOR: quic: Wrong connection ID to thread ID association
1085 - BUG/MINOR: task: always reset a new tasklet's call date
1086 - BUG/MINOR: task: make task_instant_wakeup() work on a task not a tasklet
1087 - MINOR: task: permanently enable latency measurement on tasklets
1088 - CLEANUP: task: rename ->call_date to ->wake_date
1089 - BUG/MINOR: sched: properly account for the CPU time of dying tasks
1090 - MINOR: sched: store the current profile entry in the thread context
1091 - BUG/MINOR: stream/sched: take into account CPU profiling for the last call
1092 - MINOR: tasks: do not keep cpu and latency times in struct task
1093 - MINOR: tools: add generic pointer hashing functions
1094 - CLEANUP: activity: make memprof use the generic ptr_hash() function
1095 - CLEANUP: activity: make taskprof use ptr_hash()
1096 - MINOR: debug: add struct ha_caller to describe a calling location
1097 - CLEANUP: debug: use struct ha_caller for memstat
1098 - DEBUG: task: define a series of wakeup types for tasks and tasklets
1099 - DEBUG: task: use struct ha_caller instead of arrays of file:line
1100 - DEBUG: applet: instrument appctx_wakeup() to log the caller's location
1101 - DEBUG: task: simplify the caller recording in DEBUG_TASK
1102 - CLEANUP: task: move tid and wake_date into the common part
1103 - CLEANUP: sched: remove duplicate code in run_tasks_from_list()
1104 - CLEANUP: activity: make the number of sched activity entries more configurable
1105 - DEBUG: resolvers: unstatify process_resolvers() to make it appear in profiling
1106 - DEBUG: quic: export the few task handlers that often appear in task dumps
1107 - MEDIUM: tasks/activity: combine the called function with the caller
1108 - MINOR: tasks/activity: improve the caller-callee activity hash
1109 - MINOR: activity/cli: support aggregating task profiling outputs
1110 - MINOR: activity/cli: support sorting task profiling by total CPU time
1111 - BUG/MINOR: signals/poller: set the poller timeout to 0 when there are signals
1112 - BUG/MINOR: quic: Speed up the handshake completion only one time
1113 - BUG/MINOR: quic: Trace fix about packet number space information.
1114 - BUG/MINOR: h3: Crash when h3 trace verbosity is "minimal"
1115 - MINOR: h3: Add the quic_conn object to h3 traces
1116 - MINOR: h3: Missing connection argument for a TRACE_LEAVE() argument
1117 - MINOR: h3: Send the h3 settings with others streams (requests)
1118 - MINOR: dev/udp: Apply the corruption to both directions
1119 - BUILD: udp-perturb: Add a make target for udp-perturb tool
1120 - BUG/MINOR: signals/poller: ensure wakeup from signals
1121 - CI: cirrus-ci: bump FreeBSD image to 13-1
1122 - DEV: flags: fix usage message to reflect available options
1123 - DEV: flags: add missing CO_FL_FDLESS connection flag
1124 - MINOR: flags: add a new file to host flag dumping macros
1125 - MINOR: flags: implement a macro used to dump enums inside masks
1126 - MINOR: flags/channel: use flag dumping for channel flags and analysers
1127 - MINOR: flags/connection: use flag dumping for connection flags
1128 - MINOR: flags/stconn: use flag dumping for stconn and sedesc flags
1129 - MINOR: flags/stream: use flag dumping for stream error type
1130 - MINOR: flags/stream: use flag dumping for stream flags
1131 - MINOR: flags/task: use flag dumping for task state
1132 - MINOR: flags/http_ana: use flag dumping for txn flags
1133 - DEV: flags: remove the now unused SHOW_FLAG() definition
1134 - DEV: flags: remove the now useless intermediary functions
1135 - MINOR: flags/htx: use flag dumping to show htx and start-line flags
1136 - MINOR: flags/http_ana: use flag dumping to show http msg states
1137 - BUG/MEDIUM: proxy: ensure pause_proxy() and resume_proxy() own PROXY_LOCK
1138 - MINOR: listener: small API change
1139 - MINOR: proxy/listener: support for additional PAUSED state
1140 - BUG/MINOR: stats: fixing stat shows disabled frontend status as 'OPEN'
1141 - BUILD: flags: fix build warning in some macros used by show_flags
1142 - BUILD: flags: fix the fallback macros for missing stdio
1143 - CLEANUP: pollers: remove dead code in the polling loop
1144 - BUG/MINOR: mux-h1: Increment open_streams counter when H1 stream is created
1145 - REGTESTS: healthcheckmail: Relax matching on the healthcheck log message
1146 - CLEANUP: listener: function comment typo in stop_listener()
1147 - BUG/MINOR: listener: null pointer dereference suspected by coverity
1148 - MINOR: flags/fd: decode FD flags states
1149 - REORG: mux-h2: extract flags and enums into mux_h2-t.h
1150 - MINOR: flags/mux-h2: decode H2C and H2S flags
1151 - REGTESTS: log: test the log-forward feature
1152 - BUG/MEDIUM: sink: bad init sequence on tcp sink from a ring.
1153 - REGTESTS: ssl/log: test the log-forward with SSL
1154 - MEDIUM: httpclient: httpclient_create_proxy() creates a proxy for httpclient
1155 - MEDIUM: httpclient: allow to use another proxy
1156 - DOC: fix TOC in starter guide for subsection 3.3.8. Statistics
1157 - MINOR: httpclient: export httpclient_create_proxy()
1158 - MEDIUM: quic: separate path for rx and tx with set_encryption_secrets
1159 - BUG/MEDIUM: mux-quic: fix crash on early app-ops release
1160 - REORG: mux-h1: extract flags and enums into mux_h1-t.h
1161 - MINOR: flags/mux-h1: decode H1C and H1S flags
1162 - CLEANUP: mux-quic: remove stconn usage in h3/hq
1163 - BUG/MINOR: mux-quic: do not remotely close stream too early
1164 - CLEANUP: exclude udp-perturb with .gitignore
1165 - BUG/MEDIUM: server: segv when adding server with hostname from CLI
1166 - CLEANUP: quic,ssl: fix tiny typos in C comments
1167 - BUG/MEDIUM: captures: free() an error capture out of the proxy lock
1168 - BUILD: fd: fix a build warning on the DWCAS
1169 - MINOR: anon: add new macros and functions to anonymize contents
1170 - MINOR: anon: store the anonymizing key in the global structure
1171 - MINOR: anon: store the anonymizing key in the CLI's appctx
1172 - MINOR: cli: anonymize commands 'show sess' and 'show sess all'
1173 - MINOR: cli: anonymize 'show servers state' and 'show servers conn'
1174 - MINOR: config: add command-line -dC to dump the configuration file
1175 - SCRIPTS: announce-release: update some URLs to https
1176
Willy Tarreau3bb2b5d2022-09-02 19:36:50 +020011772022/09/02 : 2.7-dev5
1178 - BUG/MINOR: mux-quic: Fix memleak on QUIC stream buffer for unacknowledged data
1179 - BUG/MEDIUM: cpu-map: fix thread 1's affinity affecting all threads
1180 - MINOR: cpu-map: remove obsolete diag warning about combined ranges
1181 - BUG/MAJOR: mworker: fix infinite loop on master with no proxies.
1182 - REGTESTS: launch http_reuse_always in mworker mode
1183 - BUG/MINOR: quix: Memleak for non in flight TX packets
1184 - BUG/MINOR: quic: Wrong list_for_each_entry() use when building packets from qc_do_build_pkt()
1185 - BUG/MINOR: quic: Safer QUIC frame builders
1186 - MINOR: quic: Replace MT_LISTs by LISTs for RX packets.
1187 - BUG/MEDIUM: applet: fix incorrect check for abnormal return condition from handler
1188 - BUG/MINOR: applet: make the call_rate only count the no-progress calls
1189 - MEDIUM: peers: limit the number of updates sent at once
1190 - BUILD: tcp_sample: fix build of get_tcp_info() on OpenBSD
1191 - BUG/MINOR: resolvers: return the correct value in resolvers_finalize_config()
1192 - BUG/MINOR: mworker: does not create the "default" resolvers in wait mode
1193 - BUG/MINOR: tcpcheck: Disable QUICKACK only if data should be sent after connect
1194 - REGTESTS: Fix prometheus script to perform HTTP health-checks
1195 - MINOR: resolvers: shut the warning when "default" resolvers is implicit
1196 - Revert "BUG/MINOR: quix: Memleak for non in flight TX packets"
1197 - BUG/MINOR: quic: Leak in qc_release_lost_pkts() for non in flight TX packets
1198 - BUG/MINOR: quic: Stalled connections (missing I/O handler wakeup)
1199 - CLEANUP: quic: No more use ->rx_list MT_LIST entry point (quic_rx_packet)
1200 - CLEANUP: quic: Remove a useless check in qc_lstnr_pkt_rcv()
1201 - MINOR: quic: Remove useless traces about references to TX packets
1202 - Revert "MINOR: quic: Remove useless traces about references to TX packets"
1203 - DOC: configuration: do-resolve doesn't work with a port in the string
1204 - MINOR: sample: add the host_only and port_only converters
1205 - BUG/MINOR: httpclient: fix resolution with port
1206 - DOC: configuration.txt: do-resolve must use host_only to remove its port.
1207 - BUG/MINOR: quic: Null packet dereferencing from qc_dup_pkt_frms() trace
1208 - BUG/MINOR: quic: Frames added to packets even if not built.
1209 - BUG/MEDIUM: spoe: Properly update streams waiting for a ACK in async mode
1210 - BUG/MEDIUM: peers: Add connect and server timeut to peers proxy
1211 - BUG/MEDIUM: peers: Don't use resync timer when local resync is in progress
1212 - BUG/MEDIUM: peers: Don't start resync on reload if local peer is not up-to-date
1213 - BUG/MINOR: hlua: Rely on CF_EOI to detect end of message in HTTP applets
1214 - BUG/MEDIUM: mux-h1: do not refrain from signaling errors after end of input
1215 - BUG/MINOR: epoll: do not actively poll for Rx after an error
1216 - MINOR: raw-sock: don't try to send if an error was already reported
1217 - BUG/MINOR: quic: Missing header protection AES cipher context initialisations (draft-v2)
1218 - MINOR: quic: Add a trace to distinguish the datagram from the packets inside
1219 - BUG/MINOR: ssl: fix deinit of the ca-file tree
1220 - BUG/MINOR: ssl: leak of ckch_inst_link in ckch_inst_free()
1221 - BUG/MINOR: tcpcheck: Disable QUICKACK for default tcp-check (with no rule)
1222 - BUG/MEDIUM: ssl: Fix a UAF when old ckch instances are released
1223 - BUG/MINOR: ssl: revert two wrong fixes with ckhi_link
1224 - BUG/MINOR: dev/udp: properly preset the rx address size
1225 - BUILD: debug: make sure debug macros are never empty
1226 - MINOR: quic: Move traces about RX/TX bytes from QUIC_EV_CONN_PRSAFRM event
1227 - BUG/MINOR: quic: TX frames memleak
1228 - BUG/MINOR: ssl: leak of ckch_inst_link in ckch_inst_free() v2
1229 - MINOR: sink/ring: rotate non-empty file-backed contents only
1230 - BUG/MINOR: regex: Properly handle PCRE2 lib compiled without JIT support
1231 - REGTESTS: http_request_buffer: Add a barrier to not mix up log messages
1232 - BUG/MEDIUM: mux-h1: always use RST to kill idle connections in pools
1233 - MINOR: backend: always satisfy the first req reuse rule with l7 retries
1234 - BUG/MINOR: quic: Do not ack when probing
1235 - MINOR: quic: Add TX frames addresses to traces to several trace events
1236 - MINOR: quic: Trace typo fix in qc_release_frm()
1237 - BUG/MINOR: quic: Frames leak during retransmissions
1238 - BUG/MINOR: h2: properly set the direction flag on HTX response
1239 - BUG/MEDIUM: httpclient: always detach the caller before self-killing
1240 - BUG/MINOR: httpclient: only ask for more room on failed writes
1241 - BUG/MINOR: httpclient: keep-alive was accidentely disabled
1242 - MEDIUM: httpclient: enable ALPN support on outgoing https connections
1243 - BUG/MINOR: mux-h2: fix the "show fd" dest buffer for the subscriber
1244 - BUG/MINOR: mux-h1: fix the "show fd" dest buffer for the subscriber
1245 - BUG/MINOR: mux-fcgi: fix the "show fd" dest buffer for the subscriber
1246 - DEBUG: stream: minor rearrangement of a few fields in struct stream.
1247 - MINOR: debug: report applet pointer and handler in crashes when known
1248 - MINOR: mux-h2: extract the stream dump function out of h2_show_fd()
1249 - MINOR: mux-h2: extract the connection dump function out of h2_show_fd()
1250 - MINOR: muxes: add a "show_sd" helper to complete "show sess" dumps
1251 - MINOR: mux-h2: provide a "show_sd" helper to output stream debugging info
1252 - MINOR: mux-h2: insert line breaks in "show sess all" output for legibility
1253 - MINOR: mux-quic: provide a "show_sd" helper to output stream debugging info
1254 - MINOR: mux-h1: split "show_fd" into connection and stream
1255 - MINOR: mux-h1: provide a "show_sd" helper to output stream debugging info
1256 - BUG/MINOR: http-act: initialize http fmt head earlier
1257
Willy Tarreauf5320192022-08-20 15:56:31 +020012582022/08/20 : 2.7-dev4
1259 - BUG/MEDIUM: quic: Wrong packet length check in qc_do_rm_hp()
1260 - MINOR: quic: Too much useless traces in qc_build_frms()
1261 - BUG/MEDIUM: quic: Missing AEAD TAG check after removing header protection
1262 - MINOR: quic: Replace pool_zalloc() by pool_malloc() for fake datagrams
1263 - MINOR: debug: make the mem_stats section aligned to void*
1264 - MINOR: debug: store and report the pool's name in struct mem_stats
1265 - MINOR: debug: also store the function name in struct mem_stats
1266 - MINOR: debug/memstats: automatically determine first column size
1267 - MINOR: debug/memstats: permit to pass the size to free()
1268 - CLEANUP: mux-quic: remove loop on sending frames
1269 - MINOR: quic: replace custom buf on Tx by default struct buffer
1270 - MINOR: quic: release Tx buffer on each send
1271 - MINOR: quic: refactor datagram commit in Tx buffer
1272 - MINOR: quic: skip sending if no frame to send in io-cb
1273 - BUG/MINOR: mux-quic: open stream on STOP_SENDING
1274 - BUG/MINOR: quic: fix crash on handshake io-cb for null next enc level
1275 - BUG/MEDIUM: quic: always remove the connection from the accept list on close
1276 - BUG/MEDIUM: poller: use fd_delete() to release the poller pipes
1277 - BUG/MEDIUM: task: relax one thread consistency check in task_unlink_wq()
1278 - MEDIUM: quic: xprt traces rework
1279 - BUILD: stconn: fix build warning at -O3 about possible null sc
1280 - MINOR: quic: Remove useless lock for RX packets
1281 - BUG/MINOR: quic: Possible infinite loop in quic_build_post_handshake_frames()
1282 - CLEANUP: quic: Remove trailing spaces
1283 - MINOR: mux-quic: adjust enter/leave traces
1284 - MINOR: mux-quic: define protocol error traces
1285 - CLEANUP: mux-quic: adjust traces level
1286 - MINOR: mux-quic: define new traces
1287 - BUG/MEDIUM: mux-quic: fix crash due to invalid trace arg
1288 - BUG/MEDIUM: quic: Possible use of uninitialized <odcid> variable in qc_lstnr_params_init()
1289 - BUG/MEDIUM: ring: fix too lax 'size' parser
1290 - BUG/MEDIUM: quic: Wrong use of <token_odcid> in qc_lsntr_pkt_rcv()
1291 - BUILD: ring: forward-declare struct appctx to avoid a build warning
1292 - MINOR: ring: support creating a ring from a linear area
1293 - MINOR: ring: add support for a backing-file
1294 - DEV: haring: add a simple utility to read file-backed rings
1295 - DEV: haring: support remapping LF in contents with CR VT
1296 - BUG/MINOR: quic: memleak on wrong datagram receipt
1297 - BUILD: sink: replace S_IRUSR, S_IWUSR with their octal value
1298 - MINOR: ring: archive a previous file-backed ring on startup
1299 - BUG/MINOR: mux-quic: fix crash with traces in qc_detach()
1300 - BUG/MINOR: quic: MIssing check when building TX packets
1301 - BUG/MINOR: quic: Wrong status returned by qc_pkt_decrypt()
1302 - MINOR: memprof: export the minimum definitions for memory profiling
1303 - MINOR: pool/memprof: report pool alloc/free in memory profiling
1304 - MINOR: pools/memprof: store and report the pool's name in each bin
1305 - MINOR: chunk: inline alloc_trash_chunk()
1306 - MINOR: stick-table: Add table_expire() and table_idle() new converters
1307 - CLEANUP: exclude haring with .gitignore
1308 - MINOR: quic: adjust quic_frame flag manipulation
1309 - MINOR: h3: report error on control stream close
1310 - MINOR: qpack: report error on enc/dec stream close
1311 - BUG/MEDIUM: mux-quic: reject uni stream ID exceeding flow control
1312 - MINOR: mux-quic: adjust traces on stream init
1313 - MINOR: mux-quic: add missing args on some traces
1314 - MINOR: quic: refactor application send
1315 - BUG/MINOR: quic: do not notify MUX on frame retransmit
1316 - BUG/MEDIUM: http-ana: fix crash or wrong header deletion by http-restrict-req-hdr-names
1317 - BUG/MINOR: quic: Missing initializations for ducplicated frames.
1318 - BUG/MEDIUM: quic: fix crash on MUX send notification
1319 - REORG: h2: extract cookies concat function in http_htx
1320 - REGTESTS: add test for HTTP/2 cookies concatenation
1321 - MEDIUM: h3: concatenate multiple cookie headers
1322 - MINOR: applet: add a function to reset the svcctx of an applet
1323 - BUG/MEDIUM: cli: always reset the service context between commands
1324 - BUG/MEDIUM: mux-h2: do not fiddle with ->dsi to indicate demux is idle
1325 - MINOR: mux-h2/traces: report transition to SETTINGS1 before not after
1326 - MINOR: mux-h2: make streams know if they need to send more data
1327 - BUG/MINOR: mux-h2: send a CANCEL instead of ES on truncated writes
1328 - BUG/MINOR: quic: Possible crashes when dereferencing ->pkt quic_frame struct member
1329 - MINOR: quic: Add frame addresses to QUIC_EV_CONN_PRSAFRM event traces
1330 - BUG/MINOR: quic: Wrong splitted duplicated frames handling
1331 - MINOR: quic: Add the QUIC connection to mux traces
1332 - MINOR: quic: Trace fix in qc_release_frm()
1333 - BUG/MAJOR: log-forward: Fix log-forward proxies not fully initialized
1334 - BUG/MAJOR: log-forward: Fix ssl layer not initialized on bind even if configured
1335 - MINOR: quic: Add reusable cipher contexts for header protection
1336 - BUG/MINOR: ssl/cli: error when the ca-file is empty
1337 - MINOR: ssl: handle ca-file appending in cafile_entry
1338 - MINOR: ssl/cli: implement "add ssl ca-file"
1339
Willy Tarreau87e95d32022-08-07 17:28:59 +020013402022/08/07 : 2.7-dev3
1341 - BUILD: makefile: Fix install(1) handling for OpenBSD/NetBSD/Solaris/AIX
1342 - BUG/MEDIUM: tools: avoid calling dlsym() in static builds (try 2)
1343 - MINOR: resolvers: resolvers_destroy() deinit and free a resolver
1344 - BUG/MINOR: resolvers: shut off the warning for the default resolvers
1345 - BUG/MINOR: ssl: allow duplicate certificates in ca-file directories
1346 - BUG/MINOR: tools: fix statistical_prng_range()'s output range
1347 - BUG/MINOR: quic: do not send CONNECTION_CLOSE_APP in initial/handshake
1348 - BUILD: debug: Add braces to if statement calling only CHECK_IF()
1349 - BUG/MINOR: fd: Properly init the fd state in fd_insert()
1350 - BUG/MEDIUM: fd/threads: fix incorrect thread selection in wakeup broadcast
1351 - MINOR: init: load OpenSSL error strings
1352 - MINOR: ssl: enhance ca-file error emitting
1353 - BUG/MINOR: mworker/cli: relative pid prefix not validated anymore
1354 - BUG/MAJOR: mux_quic: fix invalid PROTOCOL_VIOLATION on POST data overlap
1355 - BUG/MEDIUM: mworker: proc_self incorrectly set crashes upon reload
1356 - BUILD: add detection for unsupported compiler models
1357 - BUG/MEDIUM: stconn: Only reset connect expiration when processing backend side
1358 - BUG/MINOR: backend: Fallback on RR algo if balance on source is impossible
1359 - BUG/MEDIUM: master: force the thread count earlier
1360 - BUG/MAJOR: poller: drop FD's tgid when masks don't match
1361 - DEBUG: fd: detect possibly invalid tgid in fd_insert()
1362 - BUG/MINOR: sockpair: wrong return value for fd_send_uxst()
1363 - MINOR: sockpair: move send_fd_uxst() error message in caller
1364 - Revert "BUG/MINOR: peers: set the proxy's name to the peers section name"
1365 - DEBUG: fd: split the fd check
1366 - MEDIUM: resolvers: continue startup if network is unavailable
1367 - BUG/MINOR: fd: always remove late updates when freeing fd_updt[]
1368 - MINOR: cli: emit a warning when _getsocks was used more than once
1369 - BUG/MINOR: mworker: PROC_O_LEAVING used but not updated
1370 - Revert "MINOR: cli: emit a warning when _getsocks was used more than once"
1371 - MINOR: cli: warning on _getsocks when socket were closed
1372 - BUG/MEDIUM: mux-quic: fix missing EOI flag to prevent streams leaks
1373 - MINOR: quic: Congestion control architecture refactoring
1374 - MEDIUM: quic: Cubic congestion control algorithm implementation
1375 - MINOR: quic: New "quic-cc-algo" bind keyword
1376 - BUG/MINOR: quic: loss time limit variable computed but not used
1377 - MINOR: quic: Stop looking for packet loss asap
1378 - BUG/MAJOR: quic: Useless resource intensive loop qc_ackrng_pkts()
1379 - MINOR: quic: Send packets as much as possible from qc_send_app_pkts()
1380 - BUG/MEDIUM: queue/threads: limit the number of entries dequeued at once
1381 - MAJOR: threads/plock: update the embedded library
1382 - MINOR: thread: provide an alternative to pthread's rwlock
1383 - DEBUG: tools: provide a tree dump function for ebmbtrees as well
1384 - MINOR: ebtree: add ebmb_lookup_shorter() to pursue lookups
1385 - BUG/MEDIUM: pattern: only visit equivalent nodes when skipping versions
1386 - BUG/MINOR: mux-quic: prevent crash if conn released during IO callback
1387 - CLEANUP: mux-quic: remove useless app_ops is_active callback
1388 - BUG/MINOR: mux-quic: do not free conn if attached streams
1389 - MINOR: mux-quic: save proxy instance into qcc
1390 - MINOR: mux-quic: use timeout server for backend conns
1391 - MEDIUM: mux-quic: adjust timeout refresh
1392 - MINOR: mux-quic: count in-progress requests
1393 - MEDIUM: mux-quic: implement http-keep-alive timeout
1394 - MINOR: peers: Add a warning about incompatible SSL config for the local peer
1395 - MINOR: peers: Use a dedicated reconnect timeout when stopping the local peer
1396 - BUG/MEDIUM: peers: limit reconnect attempts of the old process on reload
1397 - BUG/MINOR: peers: Use right channel flag to consider the peer as connected
1398 - BUG/MEDIUM: dns: Properly initialize new DNS session
1399 - BUG/MINOR: backend: Don't increment conn_retries counter too early
1400 - MINOR: server: Constify source server to copy its settings
1401 - REORG: server: Export srv_settings_cpy() function
1402 - BUG/MEDIUM: proxy: Perform a custom copy for default server settings
1403 - BUG/MINOR: quic: Missing in flight ack eliciting packet counter decrement
1404 - BUG/MEDIUM: quic: Floating point exception in cubic_root()
1405 - MINOR: h3: support HTTP request framing state
1406 - MINOR: mux-quic: refresh timeout on frame decoding
1407 - MINOR: mux-quic: refactor refresh timeout function
1408 - MEDIUM: mux-quic: implement http-request timeout
1409 - BUG/MINOR: quic: Avoid sending truncated datagrams
1410 - BUG/MINOR: ring/cli: fix a race condition between the writer and the reader
1411 - BUG/MEDIUM: sink: Set the sink ref for forwarders created during ring parsing
1412 - BUG/MINOR: sink: fix a race condition between the writer and the reader
1413 - BUG/MINOR: quic: do not reject datagrams matching minimum permitted size
1414 - MINOR: quic: Add two new stats counters for sendto() errors
1415 - BUG/MINOR: quic: Missing Initial packet dropping case
1416 - MINOR: quic: explicitely ignore sendto error
1417 - BUG/MINOR: quic: adjust errno handling on sendto
1418 - BUG/MEDIUM: quic: break out of the loop in quic_lstnr_dghdlr
1419 - MINOR: threads: report the number of thread groups in build options
1420 - MINOR: config: automatically preset MAX_THREADS based on MAX_TGROUPS
1421 - BUILD: SSL: allow to pass additional configure args to QUICTLS
1422 - CI: enable weekly "m32" builds on x86_64
1423 - CLEANUP: assorted typo fixes in the code and comments
1424 - BUG/MEDIUM: fix DH length when EC key is used
1425 - REGTESTS: ssl: adopt tests to OpenSSL-3.0.N
1426 - REGTESTS: ssl: adopt tests to OpenSSL-3.0.N
1427 - REGTESTS: ssl: fix grep invocation to use extended regex in ssl_generate_certificate.vtc
1428 - BUILD: cfgparse: always defined _GNU_SOURCE for sched.h and crypt.h
1429
Willy Tarreau2200a9c2022-07-16 17:17:22 +020014302022/07/16 : 2.7-dev2
1431 - BUG/MINOR: qpack: fix build with QPACK_DEBUG
1432 - MINOR: h3: handle errors on HEADERS parsing/QPACK decoding
1433 - BUG/MINOR: qpack: abort on dynamic index field line decoding
1434 - MINOR: qpack: properly handle invalid dynamic table references
1435 - MINOR: task: Add tasklet_wakeup_after()
1436 - BUG/MINOR: quic: Dropped packets not counted (with RX buffers full)
1437 - MINOR: quic: Add new stats counter to diagnose RX buffer overrun
1438 - MINOR: quic: Duplicated QUIC_RX_BUFSZ definition
1439 - MINOR: quic: Improvements for the datagrams receipt
1440 - CLEANUP: h2: Typo fix in h2_unsubcribe() traces
1441 - MINOR: quic: Increase the QUIC connections RX buffer size (upto 64Kb)
1442 - CLEANUP: mux-quic: adjust comment on qcs_consume()
1443 - MINOR: ncbuf: implement ncb_is_fragmented()
1444 - BUG/MINOR: mux-quic: do not signal FIN if gap in buffer
1445 - MINOR: fd: add a new FD_DISOWN flag to prevent from closing a deleted FD
1446 - BUG/MEDIUM: ssl/fd: unexpected fd close using async engine
1447 - MINOR: tinfo: make tid temporarily still reflect global ID
1448 - CLEANUP: config: remove unused proc_mask()
1449 - MINOR: debug: remove mask support from "debug dev sched"
1450 - MEDIUM: task: add and preset a thread ID in the task struct
1451 - MEDIUM: task/debug: move the ->thread_mask integrity checks to ->tid
1452 - MAJOR: task: use t->tid instead of ffsl(t->thread_mask) to take the thread ID
1453 - MAJOR: task: replace t->thread_mask with 1<<t->tid when thread mask is needed
1454 - CLEANUP: task: remove thread_mask from the struct task
1455 - MEDIUM: applet: only keep appctx_new_*() and drop appctx_new()
1456 - MEDIUM: task: only keep task_new_*() and drop task_new()
1457 - MINOR: applet: always use task_new_on() on applet creation
1458 - MEDIUM: task: remove TASK_SHARED_WQ and only use t->tid
1459 - MINOR: task: replace task_set_affinity() with task_set_thread()
1460 - CLEANUP: task: remove the unused task_unlink_rq()
1461 - CLEANUP: task: remove the now unused TASK_GLOBAL flag
1462 - MINOR: task: make rqueue_ticks atomic
1463 - MEDIUM: task: move the shared runqueue to one per thread
1464 - MEDIUM: task: replace the global rq_lock with a per-rq one
1465 - MINOR: task: remove grq_total and use rq_total instead
1466 - MINOR: task: replace global_tasks_mask with a check for tree's emptiness
1467 - MEDIUM: task: use regular eb32 trees for the run queues
1468 - MEDIUM: queue: revert to regular inter-task wakeups
1469 - MINOR: thread: make wake_thread() take care of the sleeping threads mask
1470 - MINOR: thread: move the flags to the shared cache line
1471 - MINOR: thread: only use atomic ops to touch the flags
1472 - MINOR: poller: centralize poll return handling
1473 - MEDIUM: polling: make update_fd_polling() not care about sleeping threads
1474 - MINOR: poller: update_fd_polling: wake a random other thread
1475 - MEDIUM: thread: add a new per-thread flag TH_FL_NOTIFIED to remember wakeups
1476 - MEDIUM: tasks/fd: replace sleeping_thread_mask with a TH_FL_SLEEPING flag
1477 - MINOR: tinfo: add the tgid to the thread_info struct
1478 - MINOR: tinfo: replace the tgid with tgid_bit in tgroup_info
1479 - MINOR: tinfo: add the mask of enabled threads in each group
1480 - MINOR: debug: use ltid_bit in ha_thread_dump()
1481 - MINOR: wdt: use ltid_bit in wdt_handler()
1482 - MINOR: clock: use ltid_bit in clock_report_idle()
1483 - MINOR: thread: use ltid_bit in ha_tkillall()
1484 - MINOR: thread: add a new all_tgroups_mask variable to know about active tgroups
1485 - CLEANUP: thread: remove thread_sync_release() and thread_sync_mask
1486 - MEDIUM: tinfo: add a dynamic thread-group context
1487 - MEDIUM: thread: make stopping_threads per-group and add stopping_tgroups
1488 - MAJOR: threads: change thread_isolate to support inter-group synchronization
1489 - MINOR: thread: add is_thread_harmless() to know if a thread already is harmless
1490 - MINOR: debug: mark oneself harmless while waiting for threads to finish
1491 - MINOR: wdt: do not rely on threads_to_dump anymore
1492 - MEDIUM: debug: make the thread dumper not rely on a thread mask anymore
1493 - BUILD: debug: fix build issue on clang with previous commit
1494 - BUILD: debug: re-export thread_dump_state
1495 - BUG/MEDIUM: threads: fix incorrect thread group being used on soft-stop
1496 - BUG/MEDIUM: thread: check stopping thread against local bit and not global one
1497 - MINOR: proxy: use tg->threads_enabled in hard_stop() to detect stopped threads
1498 - BUILD: Makefile: Add Lua 5.4 autodetect
1499 - CI: re-enable gcc asan builds
1500 - MEDIUM: mworker: set the iocb of the socketpair without using fd_insert()
1501 - MINOR: fd: Add BUG_ON checks on fd_insert()
1502 - CLEANUP: mworker: rename mworker_pipe to mworker_sockpair
1503 - CLEANUP: mux-quic: do not export qc_get_ncbuf
1504 - REORG: mux-quic: reorganize flow-control fields
1505 - MINOR: mux-quic: implement accessor for sedesc
1506 - MEDIUM: mux-quic: refactor streams opening
1507 - MINOR: mux-quic: rename qcs flag FIN_RECV to SIZE_KNOWN
1508 - MINOR: mux-quic: emit FINAL_SIZE_ERROR on invalid STREAM size
1509 - BUG/MINOR: peers/config: always fill the bind_conf's argument
1510 - BUG/MEDIUM: peers/config: properly set the thread mask
1511 - CLEANUP: bwlim: Set pointers to NULL when memory is released
1512 - BUG/MINOR: http-check: Preserve headers if not redefined by an implicit rule
1513 - BUG/MINOR: http-act: Properly generate 103 responses when several rules are used
1514 - BUG/MEDIUM: thread: mask stopping_threads with threads_enabled when checking it
1515 - CLEANUP: thread: also remove a thread's bit from stopping_threads on stop
1516 - BUG/MINOR: peers: fix possible NULL dereferences at config parsing
1517 - BUG/MINOR: http-htx: Fix scheme based normalization for URIs wih userinfo
1518 - MINOR: http: Add function to get port part of a host
1519 - MINOR: http: Add function to detect default port
1520 - BUG/MEDIUM: h1: Improve authority validation for CONNCET request
1521 - MINOR: http-htx: Use new HTTP functions for the scheme based normalization
1522 - BUG/MEDIUM: http-fetch: Don't fetch the method if there is no stream
1523 - REGTEESTS: filters: Fix CONNECT request in random-forwarding script
1524 - MEDIUM: mworker/systemd: send STATUS over sd_notify
1525 - BUG/MINOR: mux-h1: Be sure to commit htx changes in the demux buffer
1526 - BUG/MEDIUM: http-ana: Don't wait to have an empty buf to switch in TUNNEL state
1527 - BUG/MEDIUM: mux-h1: Handle connection error after a synchronous send
1528 - MEDIUM: epoll: don't synchronously delete migrated FDs
1529 - BUILD: debug: silence warning on gcc-5
1530 - BUILD: http: silence an uninitialized warning affecting gcc-5
1531 - BUG/MEDIUM: mux-quic: fix server chunked encoding response
1532 - REORG: mux-quic: rename stream initialization function
1533 - MINOR: mux-quic: rename stream purge function
1534 - MINOR: mux-quic: add traces on frame parsing functions
1535 - MINOR: mux-quic: implement qcs_alert()
1536 - MINOR: mux-quic: filter send/receive-only streams on frame parsing
1537 - MINOR: mux-quic: do not ack STREAM frames on unrecoverable error
1538 - MINOR: mux-quic: support stream opening via MAX_STREAM_DATA
1539 - MINOR: mux-quic: define basic stream states
1540 - MINOR: mux-quic: use stream states to mark as detached
1541 - MEDIUM: mux-quic: implement RESET_STREAM emission
1542 - MEDIUM: mux-quic: implement STOP_SENDING handling
1543 - BUG/MEDIUM: debug: fix possible hang when multiple threads dump at once
1544 - BUG/MINOR: quic: fix closing state on NO_ERROR code sent
1545 - CLEANUP: quic: clean up include on quic_frame-t.h
1546 - MINOR: quic: define a generic QUIC error type
1547 - MINOR: mux-quic: support app graceful shutdown
1548 - MINOR: mux-quic/h3: prepare CONNECTION_CLOSE on release
1549 - MEDIUM: quic: send CONNECTION_CLOSE on released MUX
1550 - CLEANUP: mux-quic: move qc_release()
1551 - MINOR: mux-quic: send one last time before release
1552 - MINOR: h3: store control stream in h3c
1553 - MINOR: h3: implement graceful shutdown with GOAWAY
1554 - BUG/MINOR: threads: produce correct global mask for tgroup > 1
1555 - BUG/MEDIUM: cli/threads: make "show threads" more robust on applets
1556 - BUG/MINOR: thread: use the correct thread's group in ha_tkillall()
1557 - BUG/MINOR: debug: enter ha_panic() only once
1558 - BUG/MEDIUM: debug: fix parallel thread dumps again
1559 - MINOR: cli/streams: show a stream's tgid next to its thread ID
1560 - DEBUG: cli: add a new "debug dev deadlock" expert command
1561 - MINOR: cli/activity: add a thread number argument to "show activity"
1562 - CLEANUP: applet: remove the obsolete command context from the appctx
1563 - MEDIUM: config: remove deprecated "bind-process" directives from frontends
1564 - MEDIUM: config: remove the "process" keyword on "bind" lines
1565 - MINOR: listener/config: make "thread" always support up to LONGBITS
1566 - CLEANUP: fd: get rid of the __GET_{NEXT,PREV} macros
1567 - MEDIUM: debug/threads: make the lock debugging take tgroups into account
1568 - MEDIUM: proto: stop protocols under thread isolation during soft stop
1569 - MEDIUM: poller: program the update in fd_update_events() for a migrated FD
1570 - MEDIUM: poller: disable thread-groups for poll() and select()
1571 - MINOR: thread: remove MAX_THREADS limitation
1572 - MEDIUM: cpu-map: replace the process number with the thread group number
1573 - MINOR: mworker/threads: limit the mworker sockets to group 1
1574 - MINOR: cli/threads: always bind CLI to thread group 1
1575 - MINOR: fd/thread: get rid of thread_mask()
1576 - MEDIUM: task/thread: move the task shared wait queues per thread group
1577 - MINOR: task: move the niced_tasks counter to the thread group context
1578 - DOC: design: add some thoughts about how to handle the update_list
1579 - MEDIUM: conn: make conn_backend_get always scan the same group
1580 - MAJOR: fd: remove pending updates upon real close
1581 - MEDIUM: fd/poller: make the update-list per-group
1582 - MINOR: fd: delete unused updates on close()
1583 - MINOR: fd: make fd_insert() apply the thread mask itself
1584 - MEDIUM: fd: add the tgid to the fd and pass it to fd_insert()
1585 - MINOR: cli/fd: show fd's tgid and refcount in "show fd"
1586 - MINOR: fd: add functions to manipulate the FD's tgid
1587 - MINOR: fd: add fd_get_running() to atomically return the running mask
1588 - MAJOR: fd: grab the tgid before manipulating running
1589 - MEDIUM: fd/poller: turn polled_mask to group-local IDs
1590 - MEDIUM: fd/poller: turn update_mask to group-local IDs
1591 - MEDIUM: fd/poller: turn running_mask to group-local IDs
1592 - MINOR: fd: make fd_clr_running() return the previous value instead
1593 - MEDIUM: fd: make thread_mask now represent group-local IDs
1594 - MEDIUM: fd: make fd_insert() take local thread masks
1595 - MEDIUM: fd: make fd_insert/fd_delete atomically update fd.tgid
1596 - MEDIUM: fd: quit fd_update_events() when FD is closed
1597 - MEDIUM: thread: change thread_resolve_group_mask() to return group-local values
1598 - MEDIUM: listener: switch bind_thread from global to group-local
1599 - MINOR: fd: add fd_reregister_all() to deal with boot-time FDs
1600 - MEDIUM: fd: support stopping FDs during starting
1601 - MAJOR: pollers: rely on fd_reregister_all() at boot time
1602 - MAJOR: poller: only touch/inspect the update_mask under tgid protection
1603 - MEDIUM: fd: support broadcasting updates for foreign groups in updt_fd_polling
1604 - CLEANUP: threads: remove the now unused all_threads_mask and tid_bit
1605 - MINOR: config: change default MAX_TGROUPS to 16
1606 - BUG/MEDIUM: tools: avoid calling dlsym() in static builds
1607
Willy Tarreauf9de4e92022-06-24 22:09:05 +020016082022/06/24 : 2.7-dev1
1609 - BUG/MINOR: ssl_ckch: Free error msg if commit changes on a cert entry fails
1610 - BUG/MINOR: ssl_ckch: Free error msg if commit changes on a CA/CRL entry fails
1611 - BUG/MEDIUM: ssl_ckch: Don't delete a cert entry if it is being modified
1612 - BUG/MEDIUM: ssl_ckch: Don't delete CA/CRL entry if it is being modified
1613 - BUG/MINOR: ssl_ckch: Don't duplicate path when replacing a cert entry
1614 - BUG/MINOR: ssl_ckch: Don't duplicate path when replacing a CA/CRL entry
1615 - BUG/MEDIUM: ssl_ckch: Rework 'commit ssl cert' to handle full buffer cases
1616 - BUG/MEDIUM: ssl_ckch: Rework 'commit ssl ca-file' to handle full buffer cases
1617 - BUG/MEDIUM: ssl/crt-list: Rework 'add ssl crt-list' to handle full buffer cases
1618 - BUG/MEDIUM: httpclient: Don't remove HTX header blocks before duplicating them
1619 - BUG/MEDIUM: httpclient: Rework CLI I/O handler to handle full buffer cases
1620 - MEDIUM: httpclient: Don't close CLI applet at the end of a response
1621 - MEDIUM: http-ana: Always report rewrite failures as PRXCOND in logs
1622 - CLEANUP: Re-apply xalloc_size.cocci (2)
1623 - REGTESTS: abortonclose: Add a barrier to not mix up log messages
1624 - REGTESTS: http_request_buffer: Increase client timeout to wait "slow" clients
1625 - CLEANUP: ssl_ckch: Use corresponding enum for commit_cacrlfile_ctx.cafile_type
1626 - MINOR: ssl_ckch: Simplify I/O handler to commit changes on CA/CRL entry
1627 - BUG/MINOR: ssl_ckch: Use right type for old entry in show_crlfile_ctx
1628 - BUG/MINOR: ssl_ckch: Dump CRL transaction only once if show command yield
1629 - BUG/MINOR: ssl_ckch: Dump CA transaction only once if show command yield
1630 - BUG/MINOR: ssl_ckch: Dump cert transaction only once if show command yield
1631 - BUG/MINOR: ssl_ckch: Init right field when parsing "commit ssl crl-file" cmd
1632 - CLEANUP: ssl_ckch: Remove unused field in commit_cacrlfile_ctx structure
1633 - MINOR: ssl_ckch: Simplify structure used to commit changes on CA/CRL entries
1634 - MINOR: ssl_ckch: Remove service context for "set ssl cert" command
1635 - MINOR: ssl_ckch: Remove service context for "set ssl ca-file" command
1636 - MINOR: ssl_ckch: Remove service context for "set ssl crl-file" command
1637 - BUG/MINOR: ssl_ckch: Fix possible uninitialized value in show_cert I/O handler
1638 - BUG/MINOR: ssl_ckch: Fix possible uninitialized value in show_cafile I/O handler
1639 - BUG/MINOR: ssl_ckch: Fix possible uninitialized value in show_crlfile I/O handler
1640 - BUILD: ssl_ckch: Fix build error about a possible uninitialized value
1641 - BUG/MINOR: ssl_ckch: Fix another possible uninitialized value
1642 - REGTESTS: http_abortonclose: Extend supported versions
1643 - REGTESTS: restrict_req_hdr_names: Extend supported versions
1644 - MINOR: connection: support HTTP/3.0 for smp_*_http_major fetch
1645 - MINOR: h3: add h3c pointer into h3s instance
1646 - MINOR: mux-quic: simplify decode_qcs API
1647 - MINOR: mux-quic/h3: adjust demuxing function return values
1648 - BUG/MINOR: h3: fix return value on decode_qcs on error
1649 - BUILD: quic: fix anonymous union for gcc-4.4
1650 - BUILD: compiler: implement unreachable for older compilers too
1651 - DEV: tcploop: reorder options in the usage message
1652 - DEV: tcploop: make the current address the default address
1653 - DEV: tcploop: make it possible to change the target address of a connect()
1654 - DEV: tcploop: factor out the socket creation
1655 - DEV: tcploop: permit port 0 to ease handling of default options
1656 - DEV: tcploop: add a new "bind" command to bind to ip/port.
1657 - DEV: tcploop: add minimal UDP support
1658 - BUG/MINOR: trace: Test server existence for health-checks to get proxy
1659 - BUG/MINOR: checks: Properly handle email alerts in trace messages
1660 - BUG/MEDIUM: mailers: Set the object type for check attached to an email alert
1661 - REGTESTS: healthcheckmail: Update the test to be functionnal again
1662 - REGTESTS: healthcheckmail: Relax health-check failure condition
1663 - BUG/MINOR: h3: fix incorrect BUG_ON assert on SETTINGS parsing
1664 - MEDIUM: mux-h2: try to coalesce outgoing WINDOW_UPDATE frames
1665 - OPTIM: mux-h2: increase h2_settings_initial_window_size default to 64k
1666 - BUG/MINOR: h3: fix frame type definition
1667 - BUG/MEDIUM: h3: fix SETTINGS parsing
1668 - BUG/MINOR: cli/stats: add missing trailing LF after JSON outputs
1669 - BUG/MINOR: server: do not enable DNS resolution on disabled proxies
1670 - BUG/MINOR: cli/stats: add missing trailing LF after "show info json"
1671 - DOC: design: update the notes on thread groups
1672 - BUG/MEDIUM: mux-quic: fix flow control connection Tx level
1673 - MINOR: mux-quic: complete BUG_ON on TX flow-control enforcing
1674 - BUG/MINOR: mux-quic: fix memleak on frames rejected by transport
1675 - BUG/MINOR: tcp-rules: Make action call final on read error and delay expiration
1676 - CLEANUP: check: Remove useless tests on check's stream-connector
1677 - BUG/MEDIUM: stconn: Don't wakeup applet for send if it won't consume data
1678 - BUG/MEDIUM: cli: Notify cli applet won't consume data during request processing
1679 - BUG/MEDIUM: mux-quic: fix segfault on flow-control frame cleanup
1680 - MINOR: task: move profiling bit to per-thread
1681 - CLEANUP: quic: use task_new_on() for single-threaded tasks
1682 - MINOR: tinfo: remove the global thread ID bit (tid_bit)
1683 - CLEANUP: hlua: check for at least 2 threads on a task
1684 - MINOR: thread: get rid of MAX_THREADS_MASK
1685 - OPTIM: task: do not consult shared WQ when we're already full
1686 - DOC: design: update the task vs thread affinity requirements
1687 - MINOR: qpack: add comments and remove a useless trace
1688 - MINOR: qpack: reduce dependencies on other modules
1689 - BUG/MINOR: qpack: support header litteral name decoding
1690 - MINOR: qpack: add ABORT_NOW on unimplemented decoding
1691 - BUG/MINOR: h3/qpack: deal with too many headers
1692 - MINOR: qpack: improve decoding function
1693 - MINOR: qpack: implement standalone decoder tool
1694 - BUG/BUILD: h3: fix wrong label name
1695 - BUG/MINOR: quic: Stop hardcoding Retry packet Version field
1696 - MINOR: quic: Add several nonce and key definitions for Retry tag
1697 - BUG/MINOR: quic: Wrong PTO calculation
1698 - MINOR: quic: Parse long packet version from qc_parse_hd_form()
1699 - CLEANUP: quid: QUIC draft-28 no more supported
1700 - MEDIUM: quic: Add QUIC v2 draft support
1701 - MINOR: quic: Released QUIC TLS extension for QUIC v2 draft
1702 - MEDIUM: quic: Compatible version negotiation implementation (draft-08)
1703 - CLEANUP: quic: Remove any reference to boringssl
1704 - BUG/MINOR: task: fix thread assignment in tasklet_kill()
1705 - BUG/MEDIUM: stream: Properly handle destructive client connection upgrades
1706 - MINOR: stream: Rely on stconn flags to abort stream destructive upgrade
1707 - CLEANUP: stconn: Don't expect to have no sedesc on detach
1708 - BUG/MINOR: log: Properly test connection retries to fix dontlog-normal option
1709 - MINOR: hlua: don't dump empty entries in hlua_traceback()
1710 - MINOR: hlua: add a new hlua_show_current_location() function
1711 - MEDIUM: debug: add a tainted flag when a shared library is loaded
1712 - MEDIUM: debug: detect redefinition of symbols upon dlopen()
1713 - BUILD: quic: Wrong HKDF label constant variable initializations
1714 - BUG/MINOR: quic: Unexpected half open connection counter wrapping
1715 - BUG/MINOR: quic_stats: Duplicate "quic_streams_data_blocked_bidi" field name
1716 - BUG/MINOR: quic: purge conn Rx packet list on release
1717 - BUG/MINOR: quic: free rejected Rx packets
1718 - BUG/MINOR: qpack: abort on dynamic index field line decoding
1719 - BUG/MEDIUM: ssl/cli: crash when crt inserted into a crt-list
1720 - REGTESTS: ssl: add the same cert for client/server
1721 - BUG/MINOR: quic: Acknowledgement must be forced during handshake
1722 - MINOR: quic: Dump version_information transport parameter
1723 - BUG/MEDIUM: mworker: use default maxconn in wait mode
1724 - MINOR: intops: add a function to return a valid bit position from a mask
1725 - TESTS: add a unit test for one_among_mask()
1726 - BUILD: ssl_ckch: fix "maybe-uninitialized" build error on gcc-9.4 + ARM
1727 - BUG/MINOR: ssl: Do not look for key in extra files if already in pem
1728 - BUG/MINOR: quic: Missing acknowledgments for trailing packets
1729 - BUG/MINOR: http-ana: Set method to HTTP_METH_OTHER when an HTTP txn is created
1730 - BUG/MINOR: http-fetch: Use integer value when possible in "method" sample fetch
1731 - MINOR: freq_ctr: Add a function to get events excess over the current period
1732 - BUG/MINOR: stream: only free the req/res captures when set
1733 - CLEANUP: pool/tree-wide: remove suffix "_pool" from certain pool names
1734 - MEDIUM: debug: improve DEBUG_MEM_STATS to also report pool alloc/free
1735 - BUG/MINOR: quic: Wrong reuse of fulfilled dgram RX buffer
1736 - BUG/MAJOR: quic: Big RX dgrams leak when fulfilling a buffer
1737 - BUG/MAJOR: quic: Big RX dgrams leak with POST requests
1738 - BUILD: quic+h3: 32-bit compilation errors fixes
1739 - MEDIUM: bwlim: Add support of bandwith limitation at the stream level
1740
Willy Tarreau29698e32022-05-31 17:05:27 +020017412022/05/31 : 2.7-dev0
1742 - MINOR: version: it's development again
1743
Willy Tarreaua1efc042022-05-31 16:58:21 +020017442022/05/31 : 2.6.0
1745 - DOC: Fix formatting in configuration.txt to fix dconv
1746 - CLEANUP: tcpcheck: Remove useless test on the stream-connector in tcpcheck_main
1747 - CLEANUP: muxes: Consider stream's sd as defined in .show_fd callback functions
1748 - MINOR: quic: Ignore out of packet padding.
1749 - CLEANUP: quic: Useless QUIC_CONN_TX_BUF_SZ definition
1750 - CLEANUP: quic: No more used handshake output buffer
1751 - MINOR: quic: QUIC transport parameters split.
1752 - MINOR: quic: Transport parameters dump
1753 - DOC: quic: Update documentation for QUIC Retry
1754 - MINOR: quic: Tunable "max_idle_timeout" transport parameter
1755 - MINOR: quic: Tunable "initial_max_streams_bidi" transport parameter
1756 - MINOR: quic: Clarifications about transport parameters value
1757 - MINOIR: quic_stats: add QUIC connection errors counters
1758 - BUG/MINOR: quic: Largest RX packet numbers mixing
1759 - MINOR: quic_stats: Add transport new counters (lost, stateless reset, drop)
1760 - DOC: quic: Documentation update for QUIC
1761 - MINOR: quic: Connection TX buffer setting renaming.
1762 - MINOR: h3: Add a statistics module for h3
1763 - MINOR: quic: Send STOP_SENDING frames if mux is released
1764 - MINOR: quic: Do not drop packets with RESET_STREAM frames
1765 - BUG/MINOR: qpack: fix buffer API usage on prefix integer encoding
1766 - BUG/MINOR: qpack: support bigger prefix-integer encoding
1767 - BUG/MINOR: h3: do not report bug on unknown method
1768 - SCRIPTS: add make-releases-json to recreate a releases.json file in download dirs
1769 - SCRIPTS: make publish-release try to launch make-releases-json
1770 - MINOR: htx: add an unchecked version of htx_get_head_blk()
1771 - BUILD: htx: use the unchecked version of htx_get_head_blk() where needed
1772 - BUILD: quic: use inttypes.h instead of stdint.h
1773 - DOC: internal: remove totally outdated diagrams
1774 - DOC: remove the outdated ROADMAP file
1775 - DOC: add maintainers for QUIC and HTTP/3
1776 - MINOR: h3: define h3 trace module
1777 - MINOR: h3: add traces on frame recv
1778 - MINOR: h3: add traces on frame send
1779 - MINOR: h3: add traces on h3s init/end
1780 - EXAMPLES: remove completely outdated acl-content-sw.cfg
1781 - BUILD: makefile: reorder objects by build time
1782 - DOC: fix a few spelling mistakes in the docs
1783 - BUG/MEDIUM: peers/cli: fix "show peers" crash
1784 - CLEANUP: peers/cli: stop misusing the appctx local variable
1785 - CLEANUP: peers/cli: make peers_dump_peer() take an appctx instead of an stconn
1786 - BUG/MINOR: peers: set the proxy's name to the peers section name
1787 - MINOR: server: indicate when no address was expected for a server
1788 - BUG/MINOR: peers: detect and warn on init_addr/resolvers/check/agent-check
1789 - DOC: peers: indicate that some server settings are not usable
1790 - DOC: peers: clarify when entry expiration date is renewed.
1791 - DOC: peers: fix port number and addresses on new peers section format
1792 - DOC: gpc/gpt: add commments of gpc/gpt array definitions on stick tables.
1793 - DOC: install: update supported OpenSSL versions in the INSTALL doc
1794 - MINOR: ncbuf: adjust ncb_data with NCBUF_NULL
1795 - BUG/MINOR: h3: fix frame demuxing
1796 - BUG/MEDIUM: h3: fix H3_EXCESSIVE_LOAD when receiving H3 frame header only
1797 - BUG/MINOR: quic: Fix QUIC_EV_CONN_PRSAFRM event traces
1798 - CLEANUP: quic: remove useless check on local UNI stream reception
1799 - BUG/MINOR: qpack: do not consider empty enc/dec stream as error
1800 - DOC: intro: adjust the numbering of paragrams to keep the output ordered
1801 - MINOR: version: mention that it's LTS now.
1802
Willy Tarreau0edb9972022-05-27 19:49:31 +020018032022/05/27 : 2.6-dev12
1804 - CLEANUP: tools: Clean up non-QUIC error message handling in str2sa_range()
1805 - BUG/MEDIUM: tools: Fix `inet_ntop` usage in sa2str
1806 - CLEANUP: tools: Crash if inet_ntop fails due to ENOSPC in sa2str
1807 - BUG/MEDIUM: mux-quic: adjust buggy proxy closing support
1808 - Revert "MINOR: quic: activate QUIC traces at compilation"
1809 - Revert "MINOR: mux-quic: activate qmux traces on stdout via macro"
1810 - CLEANUP: init: address a coverity warning about possible multiply overflow
1811 - BUG/MEDIUM: http: Properly reject non-HTTP/1.x protocols
1812 - MEDIUM: h1: enlarge the scope of accepted version chars with accept-invalid-http-request
1813 - BUG/MEDIUM: resolvers: Don't defer resolutions release in deinit function
1814 - BUG/MEDIUM: peers: fix segfault using multiple bind on peers sections
1815 - BUG/MEDIUM: peers: prevent unitialized multiple listeners on peers section
1816 - BUG/MINOR: task: Don't defer tasks release when HAProxy is stopping
1817 - MINOR: h3: mark ncbuf as const on h3_b_dup
1818 - MINOR: mux-quic: do not alloc quic_stream_desc for uni remote stream
1819 - MINOR: mux-quic: delay cs_endpoint allocation
1820 - MINOR: mux-quic: add traces in qc_recv()
1821 - MINOR: mux-quic: adjust return value of decode_qcs
1822 - CLEANUP: h3: rename struct h3 -> h3c
1823 - CLEANUP: h3: rename uni stream type constants
1824 - BUG/MINOR: h3: prevent overflow when parsing SETTINGS
1825 - MINOR: h3: refactor h3_control_send()
1826 - MINOR: quic: support CONNECTION_CLOSE_APP emission
1827 - MINOR: mux-quic: disable read on CONNECTION_CLOSE emission
1828 - MINOR: h3: reject too big frames
1829 - MINOR: mux-quic: emit STREAM_STATE_ERROR in qcc_recv
1830 - BUG/MINOR: mux-quic: refactor uni streams TX/send H3 SETTINGS
1831 - MINOR: h3/qpack: use qcs as type in decode callbacks
1832 - MINOR: h3: define stream type
1833 - MINOR: h3: refactor uni streams initialization
1834 - MINOR: h3: check if frame is valid for stream type
1835 - MINOR: h3: define non-h3 generic parsing function
1836 - MEDIUM: quic: refactor uni streams RX
1837 - CLEANUP: h3: remove h3 uni tasklet
1838 - MINOR: h3: abort read on unknown uni stream
1839 - MINOR: h3: refactor SETTINGS parsing/error reporting
1840 - Revert "BUG/MINOR: task: Don't defer tasks release when HAProxy is stopping"
1841 - DOC: configuration: add a warning for @system-ca on bind
1842 - CLEANUP: init: address another coverity warning about a possible multiply overflow
1843 - BUG/MINOR: ssl/lua: use correctly cert_ext in CertCache.set()
1844 - BUG/MEDIUM: sample: Fix adjusting size in word converter
1845 - REGTESTS: Do not use REQUIRE_VERSION for HAProxy 2.5+ (2)
1846 - CLEANUP: conn_stream: remove unneeded exclusion of RX_WAIT_EP from RXBLK_ANY
1847 - CLEANUP: conn_stream: rename the cs_endpoint's context to "conn"
1848 - MINOR: conn_stream: add new sets of functions to set/get endpoint flags
1849 - DEV: coccinelle: add cs_endp_flags.cocci
1850 - CLEANUP: conn_stream: apply cs_endp_flags.cocci tree-wide
1851 - DEV: coccinelle: add endp_flags.cocci
1852 - CLEANUP: conn_stream: apply endp_flags.cocci tree-wide
1853 - CLEANUP: conn_stream: rename the stream endpoint flags CS_EP_* to SE_FL_*
1854 - CLEANUP: conn_stream: rename the cs_endpoint's target to "se"
1855 - CLEANUP: conn_stream: rename cs_endpoint to sedesc (stream endpoint descriptor)
1856 - CLEANUP: applet: rename the sedesc pointer from "endp" to "sedesc"
1857 - CLEANUP: conn_stream: rename the conn_stream's endp to sedesc
1858 - CLEANUP: conn_stream: rename cs_app_* to sc_app_*
1859 - CLEANUP: conn_stream: tree-wide rename to stconn (stream connector)
1860 - CLEANUP: mux-h1: add and use h1s_sc() to retrieve the stream connector
1861 - CLEANUP: mux-h2: add and use h2s_sc() to retrieve the stream connector
1862 - CLEANUP: mux-fcgi: add and use fcgi_strm_sc() to retrieve the stream connector
1863 - CLEANUP: mux-pt: add and use pt_sc() to retrieve the stream connector
1864 - CLEANUP: stdesc: rename the stream connector ->cs field to ->sc
1865 - CLEANUP: stream: rename "csf" and "csb" to "scf" and "scb"
1866 - CLEANUP: stconn: tree-wide rename stream connector flags CS_FL_* to SC_FL_*
1867 - CLEANUP: stconn: tree-wide rename stconn states CS_ST/SB_* to SC_ST/SB_*
1868 - MINOR: check: export wake_srv_chk()
1869 - MINOR: conn_stream: test the various ops functions before calling them
1870 - MEDIUM: stconn: merge the app_ops and the data_cb fields
1871 - MINOR: applet: add new wrappers to put chk/blk/str/chr to channel from appctx
1872 - CLEANUP: applet: use applet_put*() everywhere possible
1873 - CLEANUP: stconn: rename cs_{i,o}{b,c} to sc_{i,o}{b,c}
1874 - CLEANUP: stconn: rename cs_{check,strm,strm_task} to sc_strm_*
1875 - CLEANUP: stconn: rename cs_conn() to sc_conn()
1876 - CLEANUP: stconn: rename cs_mux() to sc_mux_strm()
1877 - CLEANUP: stconn: rename cs_conn_mux() to sc_mux_ops()
1878 - CLEANUP: stconn: rename cs_appctx() to sc_appctx()
1879 - CLEANUP: stconn: rename __cs_endp_target() to __sc_endp()
1880 - CLEANUP: stconn: rename cs_get_data_name() to sc_get_data_name()
1881 - CLEANUP: stconn: rename cs_conn_*() to sc_conn_*()
1882 - CLEANUP: stconn: rename cs_conn_get_first() to conn_get_first_sc()
1883 - CLEANUP: stconn: rename cs_ep_set_error() to se_fl_set_error()
1884 - CLEANUP: stconn: make a few functions take a const argument
1885 - CLEANUP: stconn: use a single function to know if SC may send to SE
1886 - MINOR: stconn: consider CF_SHUTW for sc_is_send_allowed()
1887 - MINOR: stconn: remove calls to cs_done_get()
1888 - MEDIUM: stconn: always rely on CF_SHUTR in addition to cs_rx_blocked()
1889 - MEDIUM: stconn: remove SE_FL_RXBLK_SHUT
1890 - MINOR: stconn: rename SE_FL_RXBLK_CONN to SE_FL_APPLET_NEED_CONN
1891 - MEDIUM: stconn: take SE_FL_APPLET_NEED_CONN out of the RXBLK_ANY flags
1892 - CLEANUP: stconn: rename cs_rx_room_{blk,rdy} to sc_{need,have}_room()
1893 - CLEANUP: stconn: rename cs_rx_chan_{blk,rdy} to sc_{wont,will}_read()
1894 - CLEANUP: stconn: rename cs_rx_buff_{blk,rdy} to sc_{need,have}_buff()
1895 - MINOR: stconn: start to rename cs_rx_endp_{more,done}() to se_have_{no_,}more_data()
1896 - MINOR: stconn: add sc_is_recv_allowed() to check for ability to receive
1897 - CLEANUP: stconn: rename SE_FL_RX_WAIT_EP to SE_FL_HAVE_NO_DATA
1898 - MEDIUM: stconn: move the RXBLK flags to the stream connector
1899 - CLEANUP: stconn: rename SE_FL_WANT_GET to SE_FL_WILL_CONSUME
1900 - CLEANUP: stconn: remove cs_tx_blocked() and cs_tx_endp_ready()
1901 - CLEANUP: stconn: rename cs_{want,stop}_get() to se_{will,wont}_consume()
1902 - CLEANUP: stconn: rename cs_cant_get() to se_need_more_data()
1903 - CLEANUP: stconn: rename cs_{new,create,free,destroy}_* to sc_*
1904 - CLEANUP: stconn: rename remaining management functions from cs_* to sc_*
1905 - CLEANUP: stconn: rename cs{,_get}_{src,dst} to sc_*
1906 - CLEANUP: stconn: rename cs_{shut,chk}* to sc_*
1907 - CLEANUP: stconn: rename final state manipulation functions from cs_* to sc_*
1908 - CLEANUP: quic: drop the name "conn_stream" from the pool variable names
1909 - REORG: rename cs_utils.h to sc_strm.h
1910 - REORG: stconn: rename conn_stream.{c,h} to stconn.{c,h}
1911 - CLEANUP: muxes: rename "get_first_cs" to "get_first_sc"
1912 - DEV: flags: use "sc" for stream conns instead of "cs"
1913 - CLEANUP: check: rename all occurrences of stconn "cs" to "sc"
1914 - CLEANUP: connection: rename all occurrences of stconn "cs" to "sc"
1915 - CLEANUP: stconn: rename all occurrences of stconn "cs" to "sc"
1916 - CLEANUP: quic/h3: rename all occurrences of stconn "cs" to "sc"
1917 - CLEANUP: stream: rename all occurrences of stconn "cs" to "sc"
1918 - CLEANUP: promex: rename all occurrences of stconn "cs" to "sc"
1919 - CLEANUP: stats: rename all occurrences of stconn "cs" to "sc"
1920 - CLEANUP: cli: rename all occurrences of stconn "cs" to "sc"
1921 - CLEANUP: applet: rename all occurrences of stconn "cs" to "sc"
1922 - CLEANUP: cache: rename all occurrences of stconn "cs" to "sc"
1923 - CLEANUP: dns: rename all occurrences of stconn "cs" to "sc"
1924 - CLEANUP: spoe: rename all occurrences of stconn "cs" to "sc"
1925 - CLEANUP: hlua: rename all occurrences of stconn "cs" to "sc"
1926 - CLEANUP: log-forward: rename all occurrences of stconn "cs" to "sc"
1927 - CLEANUP: http-client: rename all occurrences of stconn "cs" to "sc"
1928 - CLEANUP: mux-fcgi: rename all occurrences of stconn "cs" to "sc"
1929 - CLEANUP: mux-h1: rename all occurrences of stconn "cs" to "sc"
1930 - CLEANUP: mux-h2: rename all occurrences of stconn "cs" to "sc"
1931 - CLEANUP: mux-pt: rename all occurrences of stconn "cs" to "sc"
1932 - CLEANUP: peers: rename all occurrences of stconn "cs" to "sc"
1933 - CLEANUP: sink: rename all occurrences of stconn "cs" to "sc"
1934 - CLEANUP: sslsock: remove only occurrence of local variable "cs"
1935 - CLEANUP: applet: rename appctx_cs() to appctx_sc()
1936 - CLEANUP: stream: rename stream_upgrade_from_cs() to stream_upgrade_from_sc()
1937 - CLEANUP: obj_type: rename OBJ_TYPE_CS to OBJ_TYPE_SC
1938 - CLEANUP: stconn: replace a few remaining occurrences of CS in comments or traces
1939 - DOC: internal: update the muxes doc to mention the stconn
1940 - CLEANUP: mux-quic: rename the "endp" field to "sd"
1941 - CLEANUP: mux-h1: rename the "endp" field to "sd"
1942 - CLEANUP: mux-h2: rename the "endp" field to "sd"
1943 - CLEANUP: mux-fcgi: rename the "endp" field to "sd"
1944 - CLEANUP: mux-pt: rename the "endp" field to "sd"
1945 - CLEANUP: stconn: rename a few "endp" arguments and variables to "sd"
1946 - MINOR: stconn: turn SE_FL_WILL_CONSUME to SE_FL_WONT_CONSUME
1947 - CLEANUP: stream: remove unneeded test on appctx during initialization
1948 - CLEANUP: stconn: remove the new unneeded SE_FL_APP_MASK
1949 - DEV: flags: fix "siet" shortcut name
1950 - DEV: flags: rename the "endp" shortcut to "sd" for "stream descriptor"
1951 - DEV: flags: reorder a few SC/SE flags
1952 - DOC: internal: add a description of the stream connectors and descriptors
1953
Willy Tarreau137c8fd2022-05-20 23:31:51 +020019542022/05/20 : 2.6-dev11
1955 - CI: determine actual LibreSSL version dynamically
1956 - BUG/MEDIUM: ncbuf: fix null buffer usage
1957 - MINOR: ncbuf: fix warnings for testing build
1958 - MEDIUM: http-ana: Add a proxy option to restrict chars in request header names
1959 - MEDIUM: ssl: Delay random generator initialization after config parsing
1960 - MINOR: ssl: Add 'ssl-propquery' global option
1961 - MINOR: ssl: Add 'ssl-provider' global option
1962 - CLEANUP: Add missing header to ssl_utils.c
1963 - CLEANUP: Add missing header to hlua_fcn.c
1964 - CLEANUP: Remove unused function hlua_get_top_error_string
1965 - BUILD: fix build warning on solaris based systems with __maybe_unused.
1966 - MINOR: tools: add get_exec_path implementation for solaris based systems.
1967 - BUG/MINOR: ssl: Fix crash when no private key is found in pem
1968 - CLEANUP: conn-stream: Remove cs_applet_shut declaration from header file
1969 - MINOR: applet: Prepare appctx to own the session on frontend side
1970 - MINOR: applet: Let the frontend appctx release the session
1971 - MINOR: applet: Change return value for .init callback function
1972 - MINOR: stream: Export stream_free()
1973 - MINOR: applet: Add appctx_init() helper fnuction
1974 - MINOR: applet: Add a function to finalize frontend appctx startup
1975 - MINOR: applet: Add function to release appctx on error during init stage
1976 - MEDIUM: dns: Refactor dns appctx creation
1977 - MEDIUM: spoe: Refactor SPOE appctx creation
1978 - MEDIUM: lua: Refactor cosocket appctx creation
1979 - MEDIUM: httpclient: Refactor http-client appctx creation
1980 - MINOR: sink: Add a ref to sink in the sink_forward_target structure
1981 - MEDIUM: sink: Refactor sink forwarder appctx creation
1982 - MINOR: peers: Add a ref to peers section in the peer structure
1983 - MEDIUM: peers: Refactor peer appctx creation
1984 - MINOR: applet: Add API to start applet on a thread subset
1985 - MEDIUM: applet: Add support for async appctx startup on a thread subset
1986 - MINOR: peers: Track number of applets run by thread
1987 - MEDIUM: peers: Balance applets across threads
1988 - MINOR: conn-stream/applet: Stop setting appctx as the endpoint context
1989 - CLEANUP: proxy: Remove dead code when parsing "http-restrict-req-hdr-names" option
1990 - REGTESTS: abortonclose: Fix some race conditions
1991 - MINOR: ssl: Add 'ssl-provider-path' global option
1992 - CLEANUP: http_ana: Make use of the return value of stream_generate_unique_id()
1993 - BUG/MINOR: spoe: Fix error handling in spoe_init_appctx()
1994 - CLEANUP: peers: Remove unreachable code in peer_session_create()
1995 - CLEANUP: httpclient: Remove useless test on ss_dst in httpclient_applet_init()
1996 - BUG/MEDIUM: quic: fix Rx buffering
1997 - OPTIM: quic: realign empty Rx buffer
1998 - BUG/MINOR: ncbuf: fix ncb_is_empty()
1999 - MINOR: ncbuf: refactor ncb_advance()
2000 - BUG/MINOR: mux-quic: update session's idle delay before stream creation
2001 - MINOR: h3: do not wait a complete frame for demuxing
2002 - MINOR: h3: flag demux as full on HTX full
2003 - MEDIUM: mux-quic: implement recv on io-cb
2004 - MINOR: mux-quic: remove qcc_decode_qcs() call in XPRT
2005 - MINOR: mux-quic: reorganize flow-control frames emission
2006 - MINOR: mux-quic: implement MAX_STREAM_DATA emission
2007 - MINOR: mux-quic: implement MAX_DATA emission
2008 - BUG/MINOR: mux-quic: support nul buffer with qc_free_ncbuf()
2009 - MINOR: mux-quic: free RX buf if empty
2010 - BUG/MEDIUM: config: Reset outline buffer size on realloc error in readcfgfile()
2011 - BUG/MINOR: check: Reinit the buffer wait list at the end of a check
2012 - MEDIUM: check: No longer shutdown the connection in .wake callback function
2013 - REORG: check: Rename and export I/O callback function
2014 - MEDIUM: check: Use the CS to handle subscriptions for read/write events
2015 - BUG/MINOR: quic: break for error on sendto
2016 - MINOR: quic: abort on unlisted errno on sendto()
2017 - MINOR: quic: detect EBADF on sendto()
2018 - BUG/MEDIUM: quic: fix initialization for local/remote TPs
2019 - CLEANUP: quic: adjust comment/coding style for TPs init
2020 - BUG/MINOR: cfgparse: abort earlier in case of allocation error
2021 - MINOR: quic: Dump initial derived secrets
2022 - MINOR: quic_tls: Add quic_tls_derive_retry_token_secret()
2023 - MINOR: quic_tls: Add quic_tls_decrypt2() implementation
2024 - MINOR: quic: Retry implementation
2025 - MINOR: cfgparse: Update for "cluster-secret" keyword for QUIC Retry
2026 - MINOR: quic: Move quic_lstnr_dgram_dispatch() out of xprt_quic.c
2027 - BUILD: stats: Missing headers inclusions from stats.h
2028 - MINOR: quic_stats: Add a new stats module for QUIC
2029 - MINOR: quic: Attach proxy QUIC stats counters to the QUIC connection
2030 - BUG/MINOR: quic: Fix potential memory leak during QUIC connection allocations
2031 - MINOR: quic: QUIC stats counters handling
2032 - MINOR: quic: Add tune.quic.retry-threshold keyword
2033 - MINOR: quic: Dynamic Retry implementation
2034 - MINOR: quic/mux-quic: define CONNECTION_CLOSE send API
2035 - MINOR: mux-quic: emit FLOW_CONTROL_ERROR
2036 - MINOR: mux-quic: emit STREAM_LIMIT_ERROR
2037 - MINOR: mux-quic: close connection on error if different data at offset
2038 - BUG/MINOR: peers: fix error reporting of "bind" lines
2039 - CLEANUP: config: improve address parser error report for unmatched protocols
2040 - CLEANUP: config: provide cleare hints about unsupported QUIC addresses
2041 - MINOR: protocol: replace ctrl_type with xprt_type and clarify it
2042 - MINOR: listener: provide a function to process all of a bind_conf's arguments
2043 - MINOR: config: use the new bind_parse_args_list() to parse a "bind" line
2044 - CLEANUP: listener: add a comment about what the BC_SSL_O_* flags are for
2045 - MINOR: listener: add a new "options" entry in bind_conf
2046 - CLEANUP: listener: replace all uses of bind_conf->is_ssl with BC_O_USE_SSL
2047 - CLEANUP: listener: replace bind_conf->generate_cers with BC_O_GENERATE_CERTS
2048 - CLEANUP: listener: replace bind_conf->quic_force_retry with BC_O_QUIC_FORCE_RETRY
2049 - CLEANUP: listener: store stream vs dgram at the bind_conf level
2050 - MINOR: listener: detect stream vs dgram conflict during parsing
2051 - MINOR: listener: set the QUIC xprt layer immediately after parsing the args
2052 - MINOR: listener/ssl: set the SSL xprt layer only once the whole config is known
2053 - MINOR: connection: add flag MX_FL_FRAMED to mark muxes relying on framed xprt
2054 - MINOR: config: detect and report mux and transport incompatibilities
2055 - MINOR: listener: automatically select a QUIC mux with a QUIC transport
2056 - MINOR: listener: automatically enable SSL if a QUIC transport is found
2057 - BUG/MINOR: quic: Fixe a typo in qc_idle_timer_task()
2058 - BUG/MINOR: quic: Missing <conn_opening> stats counter decrementation
2059 - BUILD/MINOR: cpuset fix build for FreeBSD 13.1
2060 - CI: determine actual OpenSSL version dynamically
2061
Willy Tarreau37033252022-05-14 16:05:50 +020020622022/05/14 : 2.6-dev10
2063 - MINOR: ssl: ignore dotfiles when loading a dir w/ ca-file
2064 - MEDIUM: ssl: ignore dotfiles when loading a dir w/ crt
2065 - BUG/MINOR: ssl: Fix typos in crl-file related CLI commands
2066 - MINOR: compiler: add a new macro to set an attribute on an enum when possible
2067 - BUILD: stats: conditionally mark obsolete stats states as deprecated
2068 - BUILD: ssl: work around bogus warning in gcc 12's -Wformat-truncation
2069 - BUILD: debug: work around gcc-12 excessive -Warray-bounds warnings
2070 - BUILD: listener: shut report of possible null-deref in listener_accept()
2071 - BUG/MEDIUM: ssl: fix the gcc-12 broken fix :-(
2072 - DOC: install: update gcc version requirements
2073 - BUILD: makefile: add -Wfatal-errors to the default flags
2074 - BUG/MINOR: server: Make SRV_STATE_LINE_MAXLEN value from 512 to 2kB (2000 bytes).
2075 - BUG/MAJOR: dns: multi-thread concurrency issue on UDP socket
2076 - BUG/MINOR: mux-h2: mark the stream as open before processing it not after
2077 - MINOR: mux-h2: report a trace event when failing to create a new stream
2078 - DOC: configuration: add the httpclient keywords to the global keywords index
2079 - MINOR: quic: Add a debug counter for sendto() errors
2080 - BUG/MINOR: quic: Dropped peer transport parameters
2081 - BUG/MINOR: quic: Wrong unit for ack delay for incoming ACK frames
2082 - MINOR: quic: Congestion controller event trace fix (loss)
2083 - MINOR: quic: Add correct ack delay values to ACK frames
2084 - MINOR: config: Add "cluster-secret" new global keyword
2085 - MINOR: quic-tls: Add quic_hkdf_extract_and_expand() for HKDF
2086 - MINOR: quic: new_quic_cid() code moving
2087 - MINOR: quic: Initialize stateless reset tokens with HKDF secrets
2088 - MINOR: qc_new_conn() rework for stateless reset
2089 - MINOR: quic: Stateless reset token copy to transport parameters
2090 - MINOR: quic: Send stateless reset tokens
2091 - MINOR: quic: Short packets always embed a trailing AEAD TAG
2092 - CLEANUP: quic: wrong use of eb*entry() macro
2093 - CLEANUP: quic: Useless use of pointer for quic_hkdf_extract()
2094 - CLEANUP: quic_tls: QUIC_TLS_IV_LEN defined two times
2095 - MINOR: ncbuf: define non-contiguous buffer
2096 - MINOR: ncbuf: complete API and define block interal abstraction
2097 - MINOR: ncbuf: optimize storage for the last gap
2098 - MINOR: ncbuf: implement insertion
2099 - MINOR: ncbuf: define various insertion modes
2100 - MINOR: ncbuf: implement advance
2101 - MINOR: ncbuf: write unit tests
2102 - BUG/MEDIUM: lua: fix argument handling in data removal functions
2103 - DOC/MINOR: fix typos in the lua-api document
2104 - BUG/MEDIUM: wdt: don't trigger the watchdog when p is unitialized
2105 - MINOR: mux-h1: Add global option accpet payload for any HTTP/1.0 requests
2106 - CLEANUP: mux-h1: Fix comments and error messages for global options
2107 - MINOR: conn_stream: make cs_set_error() work on the endpoint instead
2108 - CLEANUP: mux-h1: always take the endp from the h1s not the cs
2109 - CLEANUP: mux-h2: always take the endp from the h2s not the cs
2110 - CLEANUP: mux-pt: always take the endp from the context not the cs
2111 - CLEANUP: mux-fcgi: always take the endp from the fstrm not the cs
2112 - CLEANUP: mux-quic: always take the endp from the qcs not the cs
2113 - CLEANUP: applet: use the appctx's endp instead of cs->endp
2114 - MINOR: conn_stream: add a pointer back to the cs from the endpoint
2115 - MINOR: mux-h1: remove the now unneeded h1s->cs
2116 - MINOR: mux-h2: make sure any h2s always has an endpoint
2117 - MINOR: mux-h2: remove the now unneeded conn_stream from the h2s
2118 - MINOR: mux-fcgi: make sure any stream always has an endpoint
2119 - MINOR: mux-fcgi: remove the now unneeded conn_stream from the fcgi_strm
2120 - MINOR: mux-quic: remove the now unneeded conn_stream from the qcs
2121 - MINOR: mux-pt: remove the now unneeded conn_stream from the context
2122 - CLEANUP: muxes: make mux->attach/detach take a conn_stream endpoint
2123 - MINOR: applet: replace cs_applet_shut() with appctx_shut()
2124 - MINOR: applet: add appctx_strm() and appctx_cs() to access common fields
2125 - CLEANUP: applet: remove the unneeded appctx->owner
2126 - CLEANUP: conn_stream: merge cs_new_from_{mux,applet} into cs_new_from_endp()
2127 - MINOR: ext-check: indicate the transport and protocol of a server
2128 - BUG/MEDIUM: mux-quic: fix a thinko in the latest cs/endpoint cleanup
2129 - MINOR: tools: improve error message accuracy in str2sa_range
2130 - MINOR: config: make sure never to mix dgram and stream protocols on a bind line
2131 - BUG/MINOR: ncbuf: fix coverity warning on uninit sz_data
2132 - MINOR: xprt_quic: adjust flow-control according to bufsize
2133 - MEDIUM: mux-quic/h3/hq-interop: use ncbuf for bidir streams
2134 - MEDIUM: mux-quic/h3/qpack: use ncbuf for uni streams
2135 - CLEANUP: mux-quic: remove unused fields for Rx
2136 - CLEANUP: quic: remove unused quic_rx_strm_frm
2137
Willy Tarreaue9797962022-05-08 11:44:15 +020021382022/05/08 : 2.6-dev9
2139 - MINOR: mux-quic: support full request channel buffer
2140 - BUG/MINOR: h3: fix parsing of unknown frame type with null length
2141 - CLEANUP: backend: make alloc_{bind,dst}_address() idempotent
2142 - MEDIUM: stream: remove the confusing SF_ADDR_SET flag
2143 - MINOR: conn_stream: remove the now unused CS_FL_ADDR_*_SET flags
2144 - CLEANUP: protocol: make sure the connect_* functions always receive a dst
2145 - MINOR: connection: get rid of the CO_FL_ADDR_*_SET flags
2146 - MINOR: session: get rid of the now unused SESS_FL_ADDR_*_SET flags
2147 - CLEANUP: mux: Useless xprt_quic-t.h inclusion
2148 - MINOR: quic: Make the quic_conn be aware of the number of streams
2149 - BUG/MINOR: quic: Dropped retransmitted STREAM frames
2150 - BUG/MINOR: mux_quic: Dropped packet upon retransmission for closed streams
2151 - MEDIUM: httpclient: remove url2sa to use a more flexible parser
2152 - MEDIUM: httpclient: http-request rules for resolving
2153 - MEDIUM: httpclient: allow address and port change for resolving
2154 - CLEANUP: httpclient: remove the comment about resolving
2155 - MINOR: httpclient: handle unix and other socket types in dst
2156 - MINOR: httpclient: rename dash by dot in global option
2157 - MINOR: init: exit() after pre-check upon error
2158 - MINOR: httpclient: cleanup the error handling in init
2159 - MEDIUM: httpclient: hard-error when SSL is configured
2160 - MINOR: httpclient: allow to configure the ca-file
2161 - MINOR: httpclient: configure the resolvers section to use
2162 - MINOR: httpclient: allow ipv4 or ipv6 preference for resolving
2163 - DOC: configuration: httpclient global option
2164 - MINOR: conn-stream: Add mask from flags set by endpoint or app layer
2165 - BUG/MEDIUM: conn-stream: Only keep app layer flags of the endpoint on reset
2166 - BUG/MEDIUM: mux-fcgi: Be sure to never set EOM flag on an empty HTX message
2167 - BUG/MEDIUM: mux-h1: Be able to handle trailers when C-L header was specified
2168 - DOC: config: Update doc for PR/PH session states to warn about rewrite failures
2169 - MINOR: resolvers: cleanup alert/warning in parse-resolve-conf
2170 - MINOR: resolvers: move the resolv.conf parser in parse_resolv_conf()
2171 - MINOR: resolvers: resolvers_new() create a resolvers with default values
2172 - BUILD: debug: unify the definition of ha_backtrace_to_stderr()
2173 - BUG/MINOR: tcp/http: release the expr of set-{src,dst}[-port]
2174 - MEDIUM: resolvers: create a "default" resolvers section at startup
2175 - DOC: resolvers: default resolvers section
2176 - BUG/MINOR: startup: usage() when no -cc arguments
2177 - BUG/MEDIUM: resolvers: make "show resolvers" properly yield
2178 - BUG/MEDIUM: cli: make "show cli sockets" really yield
2179 - BUG/MINOR: proxy/cli: don't enumerate internal proxies on "show backend"
2180 - BUG/MINOR: map/cli: protect the backref list during "show map" errors
2181 - BUG/MINOR: map/cli: make sure patterns don't vanish under "show map"'s init
2182 - BUG/MINOR: ssl/cli: fix "show ssl ca-file/crl-file" not to mix cli+ssl contexts
2183 - BUG/MINOR: ssl/cli: fix "show ssl ca-file <name>" not to mix cli+ssl contexts
2184 - BUG/MINOR: ssl/cli: fix "show ssl crl-file" not to mix cli+ssl contexts
2185 - BUG/MINOR: ssl/cli: fix "show ssl cert" not to mix cli+ssl contexts
2186 - CLEANUP: ssl/cli: do not loop on unknown states in "add ssl crt-list" handler
2187 - MINOR: applet: reserve some generic storage in the applet's context
2188 - CLEANUP: applet: make appctx_new() initialize the whole appctx
2189 - CLEANUP: stream/cli: take the "show sess" context definition out of the appctx
2190 - CLEANUP: stream/cli: stop using appctx->st2 for the dump state
2191 - CLEANUP: stream/cli: remove the unneeded init state from "show sess"
2192 - CLEANUP: stream/cli: remove the unneeded STATE_FIN state from "show sess"
2193 - CLEANUP: stream/cli: remove the now unneeded dump state from "show sess"
2194 - CLEANUP: proxy/cli: take the "show errors" context definition out of the appctx
2195 - CLEANUP: stick-table/cli: take the "show table" context definition out of the appctx
2196 - CLEANUP: stick-table/cli: stop using appctx->st2 for the dump state
2197 - CLEANUP: stick-table/cli: remove the unneeded STATE_INIT for "show table"
2198 - CLEANUP: map/cli: take the "show map" context definition out of the appctx
2199 - CLEANUP: map/cli: stop using cli.i0/i1 to store the generation numbers
2200 - CLEANUP: map/cli: stop using appctx->st2 for the dump state
2201 - CLEANUP: map/cli: always detach the backref from the list after "show map"
2202 - CLEANUP: peers/cli: take the "show peers" context definition out of the appctx
2203 - CLEANUP: peers/cli: stop using appctx->st2 for the dump state
2204 - CLEANUP: peers/cli: remove unneeded state STATE_INIT
2205 - CLEANUP: cli: initialize the whole appctx->ctx, not just the stats part
2206 - CLEANUP: promex: make the applet use its own context
2207 - CLEANUP: promex: stop using appctx->st2
2208 - CLEANUP: stats/cli: take the "show stat" context definition out of the appctx
2209 - CLEANUP: stats/cli: stop using appctx->st2
2210 - CLEANUP: hlua/cli: take the hlua_cli context definition out of the appctx
2211 - CLEANUP: ssl/cli: use a local context for "show cafile"
2212 - CLEANUP: ssl/cli: use a local context for "show crlfile"
2213 - CLEANUP: ssl/cli: use a local context for "show ssl cert"
2214 - CLEANUP: ssl/cli: use a local context for "commit ssl cert"
2215 - CLEANUP: ssl/cli: stop using appctx->st2 for "commit ssl cert"
2216 - CLEANUP: ssl/cli: use a local context for "set ssl cert"
2217 - CLEANUP: ssl/cli: use a local context for "set ssl cafile"
2218 - CLEANUP: ssl/cli: use a local context for "set ssl crlfile"
2219 - CLEANUP: ssl/cli: use a local context for "commit ssl {ca|crl}file"
2220 - CLEANUP: ssl/cli: stop using appctx->st2 for "commit ssl ca/crl"
2221 - CLEANUP: ssl/cli: stop using ctx.cli.i0/i1/p0 for "show tls-keys"
2222 - CLEANUP: ssl/cli: add a new "dump_entries" field to "show_keys_ref"
2223 - CLEANUP: ssl/cli: make "show tlskeys" not use appctx->st2 anymore
2224 - CLEANUP: ssl/cli: make "show ssl ocsp-response" not use cli.p0 anymore
2225 - CLEANUP: ssl/cli: make "{show|dump} ssl crtlist" use its own context
2226 - CLEANUP: ssl/cli: make "add ssl crtlist" use its own context
2227 - CLEANUP: ssl/cli: make "add ssl crtlist" not use st2 anymore
2228 - CLEANUP: dns: stop abusing the sink forwarder's context
2229 - CLEANUP: sink: use the generic context to store the forwarder's context
2230 - CLEANUP: activity/cli: make "show profiling" not use ctx.cli anymore
2231 - CLEANUP: debug/cli: make "debug dev fd" not use ctx.cli anymore
2232 - CLEANUP: debug/cli: make "debug dev memstats" not use ctx.cli anymore
2233 - CLEANUP: ring: pass the ring watch flags to ring_attach_cli(), not in ctx.cli
2234 - CLEANUP: ring/cli: use a locally-defined context instead of using ctx.cli
2235 - CLEANUP: resolvers/cli: make "show resolvers" use a locally-defined context
2236 - CLEANUP: resolvers/cli: remove the unneeded appctx->st2 from "show resolvers"
2237 - CLEANUP: cache/cli: make use of a locally defined context for "show cache"
2238 - CLEANUP: proxy/cli: make use of a locally defined context for "show servers"
2239 - CLEANUP: proxy/cli: get rid of appctx->st2 in "show servers"
2240 - CLEANUP: proxy/cli: make "show backend" only use the generic context
2241 - CLEANUP: cli: make "show fd" use its own context
2242 - CLEANUP: cli: make "show env" use its own context
2243 - CLEANUP: cli: simplify the "show cli sockets" I/O handler
2244 - CLEANUP: cli: make "show cli sockets" use its own context
2245 - CLEANUP: httpclient/cli: use a locally-defined context instead of ctx.cli
2246 - CLEANUP: httpclient: do not use the appctx.ctx anymore
2247 - CLEANUP: peers: do not use appctx.ctx anymore
2248 - CLEANUP: spoe: do not use appctx.ctx anymore
2249 - BUILD: applet: mark the CLI's generic variables as deprecated
2250 - BUILD: applet: mark the appctx's st2 variable as deprecated
2251 - CLEANUP: cache: take the context out of appctx.ctx
2252 - MEDIUM: lua: move the cosocket storage outside of appctx.ctx
2253 - MINOR: lua: move the tcp service storage outside of appctx.ctx
2254 - MINOR: lua: move the http service context out of appctx.ctx
2255 - CLEANUP: cli: move the status print context into its own context
2256 - CLEANUP: stats: rename the stats state values an mark the old ones deprecated
2257 - DOC: internal: document the new cleaner approach to the appctx
2258 - MINOR: tcp: socket translate TCP_KEEPIDLE for macOs equivalent
2259 - DOC: fix typo "ant" for "and" in INSTALL
2260 - CI: dynamically determine actual version of h2spec
2261
Willy Tarreau026fef92022-04-30 14:17:51 +020022622022/04/30 : 2.6-dev8
2263 - BUG/MINOR: quic: fix use-after-free with trace on ACK consume
2264 - BUG/MINOR: rules: Forbid captures in defaults section if used by a backend
2265 - BUG/MEDIUM: rules: Be able to use captures defined in defaults section
2266 - BUG/MINOR: rules: Fix check_capture() function to use the right rule arguments
2267 - BUG/MINOR: http-act: make release_http_redir() more robust
2268 - BUG/MINOR: sample: add missing use_backend/use-server contexts in smp_resolve_args
2269 - MINOR: sample: don't needlessly call c_none() in sample_fetch_as_type()
2270 - MINOR: sample: make the bool type cast to bin
2271 - MEDIUM: backend: add new "balance hash <expr>" algorithm
2272 - MINOR: init: add global setting "fd-hard-limit" to bound system limits
2273 - BUILD: pollers: use an initcall to register the pollers
2274 - BUILD: xprt: use an initcall to register the transport layers
2275 - BUILD: thread: use initcall instead of a constructor
2276 - BUILD: http: remove the two unused constructors in rules and ana
2277 - CLEANUP: compression: move the default setting of maxzlibmem to defaults
2278 - MINOR: tree-wide: always consider EWOULDBLOCK in addition to EAGAIN
2279 - BUG/MINOR: connection: "connection:close" header added despite 'close-spread-time'
2280 - MINOR: fd: add functions to set O_NONBLOCK and FD_CLOEXEC
2281 - CLEANUP: tree-wide: use fd_set_nonblock() and fd_set_cloexec()
2282 - CLEANUP: tree-wide: remove 25 occurrences of unneeded fcntl.h
2283 - REGTESTS: fix the race conditions in be2dec.vtc ad field.vtc
2284 - REGTESTS: webstats: remove unused stats socket in /tmp
2285 - MEDIUM: httpclient: disable SSL when the ca-file couldn't be loaded
2286 - BUG/MINOR: httpclient/lua: error when the httpclient_start() fails
2287 - BUG/MINOR: ssl: free the cafile entries on deinit
2288 - BUG/MINOR: ssl: memory leak when trying to load a directory with ca-file
2289 - MEDIUM: httpclient: re-enable the verify by default
2290 - BUG/MEDIUM: ssl/cli: fix yielding in show_cafile_detail
2291 - BUILD: compiler: properly distinguish weak and global symbols
2292 - MINOR: connection: Add way to disable active connection closing during soft-stop
2293 - BUG/MEDIUM: http-ana: Fix memleak in redirect rules with ignore-empty option
2294 - CLEANUP: Destroy `http_err_chunks` members during deinit
2295 - BUG/MINOR: resolvers: Fix memory leak in resolvers_deinit()
2296 - MINOR: Call deinit_and_exit(0) for `haproxy -vv`
2297 - BUILD: fd: disguise the fd_set_nonblock/cloexec result
2298 - BUG/MINOR: pools: make sure to also destroy shared pools in pool_destroy_all()
2299 - MINOR: ssl: add a new global option "tune.ssl.hard-maxrecord"
2300 - CLEANUP: errors: also call deinit_errors_buffers() on deinit()
2301 - CLEANUP: chunks: release trash also in deinit
2302 - CLEANUP: deinit: release the pre-check callbacks
2303 - CLEANUP: deinit: release the config postparsers
2304 - CLEANUP: listeners/deinit: release accept queue tasklets on deinit
2305 - CLEANUP: connections/deinit: destroy the idle_conns tasks
2306 - BUG/MINOR: mux-quic: fix build in release mode
2307 - MINOR: mux-quic: adjust comment on emission function
2308 - MINOR: mux-quic: remove unused bogus qcc_get_stream()
2309 - BUG/MINOR: mux-quic: fix leak if cs alloc failure
2310 - MINOR: mux-quic: count local flow-control stream limit on reception
2311 - BUG/MINOR: h3: fix incomplete POST requests
2312 - BUG/MEDIUM: h3: fix use-after-free on mux Rx buffer wrapping
2313 - MINOR: mux-quic: partially copy Rx frame if almost full buf
2314 - MINOR: h3: change frame demuxing API
2315 - MINOR: mux-quic: add a app-layer context in qcs
2316 - MINOR: h3: implement h3 stream context
2317 - MINOR: h3: support DATA demux if buffer full
2318 - MINOR: quic: decode as much STREAM as possible
2319 - MINOR: quic: Improve qc_prep_pkts() flexibility
2320 - MINOR: quic: Prepare quic_frame struct duplication
2321 - MINOR: quic: Do not retransmit frames from coalesced packets
2322 - MINOR: quic: Add traces about TX frame memory releasing
2323 - MINOR: quic: process_timer() rework
2324 - MEDIUM: quic: New functions for probing rework
2325 - MEDIUM: quic: Retransmission functions rework
2326 - MEDIUM: quic: qc_requeue_nacked_pkt_tx_frms() rework
2327 - MINOR: quic: old data distinction for qc_send_app_pkt()
2328 - MINOR: quic: Mark packets as probing with old data
2329 - MEDIUM: quic: Mark copies of acknowledged frames as acknowledged
2330 - MEDIUM: quic: Enable the new datagram probing process
2331 - MINOR: quic: Do not send ACK frames when probing
2332 - BUG/MINOR: quic: Wrong returned status by qc_build_frms()
2333 - BUG/MINOR: quic: Avoid sending useless PADDING frame
2334 - BUG/MINOR: quic: Traces fix about remaining frames upon packet build failure
2335 - MINOR: quic: Wake up the mux to probe with new data
2336 - BUG/MEDIUM: quic: Possible crash on STREAM frame loss
2337 - BUG/MINOR: quic: Missing Initial packet length check
2338 - CLEANUP: quic: Rely on the packet length set by qc_lstnr_pkt_rcv()
2339 - MINOR: quic: Drop 0-RTT packets if not allowed
2340 - BUG/MINOR: httpclient/ssl: use the correct verify constant
2341 - BUG/MEDIUM: conn-stream: Don't erase endpoint flags on reset
2342 - BUG/MEDIUM: httpclient: Fix loop consuming HTX blocks from the response channel
2343 - BUG/MINOR: httpclient: Count metadata in size to transfer via htx_xfer_blks()
2344 - MINOR: httpclient: Don't use co_set_data() to decrement output
2345 - BUG/MINOR: conn_stream: do not confirm a connection from the frontend path
2346 - MEDIUM: quic: do not ACK packet with STREAM if MUX not present
2347 - MEDIUM: quic: do not ack packet with invalid STREAM
2348 - MINOR: quic: Drop 0-RTT packets without secrets
2349 - CLEANUP: quic: Remaining fprintf() debug trace
2350 - MINOR: quic: moving code for QUIC loss detection
2351 - BUG/MINOR: quic: Missing time threshold multiplifier for loss delay computation
2352 - CI: github actions: update LibreSSL to 3.5.2
2353 - SCRIPTS: announce-release: add URL of dev packages
2354
Willy Tarreau3e69fcc2022-04-23 04:38:36 +020023552022/04/23 : 2.6-dev7
2356 - BUILD: calltrace: fix wrong include when building with TRACE=1
2357 - MINOR: ssl: Use DH parameters defined in RFC7919 instead of hard coded ones
2358 - MEDIUM: ssl: Disable DHE ciphers by default
2359 - BUILD: ssl: Fix compilation with OpenSSL 1.0.2
2360 - MINOR: mux-quic: split xfer and STREAM frames build
2361 - REORG: quic: use a dedicated module for qc_stream_desc
2362 - MINOR: quic-stream: use distinct tree nodes for quic stream and qcs
2363 - MINOR: quic-stream: add qc field
2364 - MEDIUM: quic: implement multi-buffered Tx streams
2365 - MINOR: quic-stream: refactor ack management
2366 - MINOR: quic: limit total stream buffers per connection
2367 - MINOR: mux-quic: implement immediate send retry
2368 - MINOR: cfg-quic: define tune.quic.conn-buf-limit
2369 - MINOR: ssl: Add 'show ssl providers' cli command and providers list in -vv option
2370 - REGTESTS: ssl: Update error messages that changed with OpenSSLv3.1.0-dev
2371 - BUG/MEDIUM: quic: Possible crash with released mux
2372 - BUG/MINOR: mux-quic: unsubscribe on release
2373 - BUG/MINOR: mux-quic: handle null timeout
2374 - BUG/MEDIUM: logs: fix http-client's log srv initialization
2375 - BUG/MINOR: mux-quic: remove dead code in qcs_xfer_data()
2376 - DEV: stream: Fix conn-streams dump in full stream message
2377 - CLEANUP: conn-stream: Rename cs_conn_close() and cs_conn_drain_and_close()
2378 - CLEANUP: conn-stream: Rename cs_applet_release()
2379 - MINOR: conn-stream: Rely on endpoint shutdown flags to shutdown an applet
2380 - BUG/MINOR: cache: Disable cache if applet creation fails
2381 - BUG/MINOR: backend: Don't allow to change backend applet
2382 - BUG/MEDIUM: conn-stream: Set back CS to RDY state when the appctx is created
2383 - MINOR: stream: Don't needlessly detach server endpoint on early client abort
2384 - MINOR: conn-stream: Make cs_detach_* private and use cs_destroy() from outside
2385 - MINOR: init: add the pre-check callback
2386 - MEDIUM: httpclient: change the init sequence
2387 - MEDIUM: httpclient/ssl: verify required
2388 - MINOR: httpclient/mworker: disable in the master process
2389 - MEDIUM: httpclient/ssl: verify is configurable and disabled by default
2390 - BUG/MAJOR: connection: Never remove connection from idle lists outside the lock
2391 - BUG/MEDIUM: mux-quic: fix stalled POST requets
2392 - BUG/MINOR: mux-quic: fix POST with abortonclose
2393 - MINOR: task: add a new task_instant_wakeup() function
2394 - MEDIUM: queue: use tasklet_instant_wakeup() to wake tasks
2395 - DOC: remove my name from the config doc
2396
Willy Tarreaua8b10652022-04-16 12:15:47 +020023972022/04/16 : 2.6-dev6
2398 - CLEANUP: connection: reduce the with of the mux dump output
2399 - CI: Update to actions/checkout@v3
2400 - CI: Update to actions/cache@v3
2401 - DOC: adjust QUIC instruction in INSTALL
2402 - BUG/MINOR: stats: define the description' background color in dark color scheme
2403 - BUILD: ssl: add USE_ENGINE and disable the openssl engine by default
2404 - BUILD: makefile: pass USE_ENGINE to cflags
2405 - BUILD: xprt-quic: replace ERR_func_error_string() with ERR_peek_error_func()
2406 - DOC: install: document the fact that SSL engines are not enabled by default
2407 - CI: github actions: disable -Wno-deprecated
2408 - BUILD: makefile: silence unbearable OpenSSL deprecation warnings
2409 - MINOR: sock: check configured limits at the sock layer, not the listener's
2410 - MINOR: connection: add a new flag CO_FL_FDLESS on fd-less connections
2411 - MINOR: connection: add conn_fd() to retrieve the FD only when it exists
2412 - MINOR: stream: only dump connections' FDs when they are valid
2413 - MINOR: connection: use conn_fd() when displaying connection errors
2414 - MINOR: connection: skip FD-based syscalls for FD-less connections
2415 - MEDIUM: connection: panic when calling FD-specific functions on FD-less conns
2416 - MINOR: mux-quic: properly set the flags and name fields
2417 - MINOR: connection: rearrange conn_get_src/dst to be a bit more extensible
2418 - MINOR: protocol: add get_src() and get_dst() at the protocol level
2419 - MINOR: quic-sock: provide a pair of get_src/get_dst functions
2420 - MEDIUM: ssl: improve retrieval of ssl_sock_ctx and SSL detection
2421 - MEDIUM: ssl: stop using conn->xprt_ctx to access the ssl_sock_ctx
2422 - MEDIUM: xprt-quic: implement get_ssl_sock_ctx()
2423 - MEDIUM: quic: move conn->qc into conn->handle
2424 - BUILD: ssl: fix build warning with previous changes to ssl_sock_ctx
2425 - BUILD: ssl: add an unchecked version of __conn_get_ssl_sock_ctx()
2426 - MINOR: ssl: refine the error testing for fc_err and fc_err_str
2427 - BUG/MINOR: sock: do not double-close the accepted socket on the error path
2428 - CI: cirrus: switch to FreeBSD-13.0
2429 - MINOR: log: add '~' to frontend when the transport layer provides SSL
2430 - BUILD/DEBUG: lru: fix printf format in debug code
2431 - BUILD: peers: adjust some printf format to silence cppcheck
2432 - BUILD/DEBUG: hpack-tbl: fix format string in standalone debug code
2433 - BUILD/DEBUG: hpack: use unsigned int in printf format in debug code
2434 - BUILD: halog: fix some incorrect signs in printf formats for integers
2435 - BUG/MINOR: h3: fix build with DEBUG_H3
2436 - BUG/MINOR: mux-h2: do not send GOAWAY if SETTINGS were not sent
2437 - BUG/MINOR: cache: do not display expired entries in "show cache"
2438 - BUG/MINOR: mux-h1: Don't release unallocated CS on error path
2439 - MINOR: applet: Make .init callback more generic
2440 - MINOR: conn-stream: Add flags to set the type of the endpoint
2441 - MEDIUM: applet: Set the appctx owner during allocation
2442 - MAJOR: conn-stream: Invert conn-stream endpoint and its context
2443 - REORG: Initialize the conn-stream by hand in cs_init()
2444 - MEDIUM: conn-stream: Add an endpoint structure in the conn-stream
2445 - MINOR: conn-stream: Move some CS flags to the endpoint
2446 - MEDIUM: conn-stream: Be able to pass endpoint to create a conn-stream
2447 - MEDIUM: conn-stream: Pre-allocate endpoint to create CS from muxes and applets
2448 - REORG: applet: Uninline appctx_new function
2449 - MAJOR: conn-stream: Share endpoint struct between the CS and the mux/applet
2450 - MEDIUM: conn-stream: Move remaning flags from CS to endpoint
2451 - MINOR: mux-pt: Rely on the endpoint instead of the conn-stream when possible
2452 - MINOR: conn-stream: Add ISBACK conn-stream flag
2453 - MINOR: conn-stream: Add header file with util functions related to conn-streams
2454 - MEDIUM: tree-wide: Use CS util functions instead of SI ones
2455 - MINOR: stream-int/txn: Move buffer for L7 retries in the HTTP transaction
2456 - CLEANUP: http-ana: Remove http_alloc_txn() function
2457 - MINOR: stream-int/stream: Move conn_retries counter in the stream
2458 - MINOR: stream: Simplify retries counter calculation
2459 - MEDIUM: stream-int/conn-stream: Move src/dst addresses in the conn-stream
2460 - MINOR: stream-int/conn-stream: Move half-close timeout in the conn-stream
2461 - MEDIUM: stream-int/stream: Use connect expiration instead of SI expiration
2462 - MINOR: stream-int/conn-stream: Report error to the CS instead of the SI
2463 - MEDIUM: conn-stream: Use endpoint error instead of conn-stream error
2464 - MINOR: channel: Use conn-streams as channel producer and consumer
2465 - MINOR: stream-int: Remove SI_FL_KILL_CON to rely on conn-stream endpoint only
2466 - MINOR: mux-h2/mux-fcgi: Fully rely on CS_EP_KILL_CONN
2467 - MINOR: stream-int: Remove SI_FL_NOLINGER/NOHALF to rely on CS flags instead
2468 - MINOR: stream-int: Remove SI_FL_DONT_WAKE to rely on CS flags instead
2469 - MINOR: stream-int: Remove SI_FL_INDEP_STR to rely on CS flags instead
2470 - MINOR: stream-int: Remove SI_FL_SRC_ADDR to rely on stream flags instead
2471 - CLEANUP: stream-int: Remove unused SI_FL_CLEAN_ABRT flag
2472 - MINOR: stream: Only save previous connection state for the server side
2473 - MEDIUM: stream-int: Move SI err_type in the stream
2474 - MEDIUM: stream-int/conn-stream: Move stream-interface state in the conn-stream
2475 - MINOR: stream-int/stream: Move si_retnclose() in the stream scope
2476 - MINOR: stream-int/backend: Move si_connect() in the backend scope
2477 - MINOR: stream-int/conn-stream: Move si_conn_ready() in the conn-stream scope
2478 - MINOR: conn-stream/connection: Move SHR/SHW modes in the connection scope
2479 - MEDIUM: conn-stream: Be prepared to fail to attach a cs to a mux
2480 - MEDIUM: stream-int/conn-stream: Handle I/O subscriptions in the conn-stream
2481 - MINOR: conn-stream: Rename CS functions dedicated to connections
2482 - MINOR: stream-int/conn-stream: Move si_shut* and si_chk* in conn-stream scope
2483 - MEDIUM: stream-int/conn-stream: Move si_ops in the conn-stream scope
2484 - MINOR: applet: Use the CS to register and release applets instead of SI
2485 - MINOR: connection: unconst mux's get_fist_cs() callback function
2486 - MINOR: stream-int/connection: Move conn_si_send_proxy() in the connection scope
2487 - REORG: stream-int: Export si_cs_recv(), si_cs_send() and si_cs_process()
2488 - REORG: stream-int: Move si_is_conn_error() in the header file
2489 - REORG: conn-stream: Move cs_shut* and cs_chk* in cs_utils
2490 - REORG: conn-stream: Move cs_app_ops in conn_stream.c
2491 - MINOR: stream-int-conn-stream: Move si_update_* in conn-stream scope
2492 - MINOR: stream-int/stream: Move si_update_both in stream scope
2493 - MEDIUM: conn-stream/applet: Add a data callback for applets
2494 - MINOR: stream-int/conn-stream: Move stream_int_read0() in the conn-stream scope
2495 - MINOR: stream-int/conn-stream: Move stream_int_notify() in the conn-stream scope
2496 - MINOR: stream-int/conn-stream: Move si_cs_io_cb() in the conn-stream scope
2497 - MINOR: stream-int/conn-stream: Move si_sync_recv/send() in conn-stream scope
2498 - MINOR: conn-stream: Move si_conn_cb in the conn-stream scope
2499 - MINOR: stream-int/conn-stream Move si_is_conn_error() in the conn-stream scope
2500 - MINOR: stream-int/conn-stream: Move si_alloc_ibuf() in the conn-stream scope
2501 - CLEANUP: stream-int: Remove unused SI functions
2502 - MEDIUM: stream-int/conn-stream: Move blocking flags from SI to CS
2503 - MEDIUM: stream-int/conn-stream: Move I/O functions to conn-stream
2504 - REORG: stream-int/conn-stream: Move remaining functions to conn-stream
2505 - MINOR: stream: Use conn-stream to report server error
2506 - MINOR: http-ana: Use CS to perform L7 retries
2507 - MEDIUM: stream: Don't use the stream-int anymore in process_stream()
2508 - MINOR: conn-stream: Remove the stream-interface from the conn-stream
2509 - DEV: flags: No longer dump SI flags
2510 - CLEANUP: tree-wide: Remove any ref to stream-interfaces
2511 - CLEANUP: conn-stream: Don't export internal functions
2512 - DOC: conn-stream: Add comments on functions of the new CS api
2513 - MEDIUM: check: Use a new conn-stream for each health-check run
2514 - CLEANUP: muxes: Remove MX_FL_CLEAN_ABRT flag
2515 - MINOR: conn-stream: Use a dedicated function to conditionally remove a CS
2516 - CLEANUP: conn-stream: rename cs_register_applet() to cs_applet_create()
2517 - MINOR: muxes: Improve show_fd callbacks to dump endpoint flags
2518 - MINOR: mux-h1: Rely on the endpoint instead of the conn-stream when possible
2519 - BUG/MINOR: quic: Avoid starting the mux if no ALPN sent by the client
2520 - BUILD: debug: mark the __start_mem_stats/__stop_mem_stats symbols as weak
2521 - BUILD: initcall: mark the __start_i_* symbols as weak, not global
2522 - BUG/MINOR: mux-h2: do not use timeout http-keep-alive on backend side
2523 - BUG/MINOR: mux-h2: use timeout http-request as a fallback for http-keep-alive
2524 - MINOR: muxes: Don't expect to have a mux without connection in destroy callback
2525 - MINOR: muxes: Don't handle proto upgrade for muxes not supporting it
2526 - MINOR: muxes: Don't expect to call release function with no mux defined
2527 - MINOR: conn-stream: Use unsafe functions to get conn/appctx in cs_detach_endp
2528 - BUG/MEDIUM: mux-h1: Don't request more room on partial trailers
2529 - BUILD: http-client: Avoid dead code when compiled without SSL support
2530 - BUG/MINOR: mux-quic: prevent a crash in session_free on mux.destroy
2531 - BUG/MINOR: quic-sock: do not double free session on conn init failure
2532 - BUG/MINOR: quic: fix return value for error in start
2533 - MINOR: quic: emit CONNECTION_CLOSE on app init error
2534 - BUILD: sched: workaround crazy and dangerous warning in Clang 14
2535 - BUILD: compiler: use a more portable set of asm(".weak") statements
2536 - BUG/MEDIUM: stream: do not abort connection setup too early
2537 - CLEANUP: extcheck: do not needlessly preset the server's address/port
2538 - MINOR: extcheck: fill in the server's UNIX socket address when known
2539 - BUG/MEDIUM: connection: Don't crush context pointer location if it is a CS
2540 - BUG/MEDIUM: quic: properly clean frames on stream free
2541 - BUG/MEDIUM: fcgi-app: Use http_msg flags to know if C-L header can be added
2542 - BUG/MEDIUM: compression: Don't forget to update htx_sl and http_msg flags
2543 - MINOR: tcp_sample: clarifying samples support per os, for further expansion.
2544 - MINOR: tcp_sample: extend support for get_tcp_info to macOs.
2545 - SCRIPTS: announce-release: update the doc's URL
2546 - DOC: lua: update a few doc URLs
2547 - SCRIPTS: announce-release: add shortened links to pending issues
2548
Willy Tarreaud3b4cd12022-04-09 11:31:40 +020025492022/04/09 : 2.6-dev5
2550 - DOC: reflect H2 timeout changes
2551 - BUG/MEDIUM: mux-fcgi: Properly handle return value of headers/trailers parsing
2552 - BUG/MEDIUM: mux-h1: Properly detect full buffer cases during message parsing
2553 - BUG/MINOR: log: Initialize the list element when allocating a new log server
2554 - BUG/MINOR: samples: add missing context names for sample fetch functions
2555 - MINOR: management: add some basic keyword dump infrastructure
2556 - MINOR: config: add a function to dump all known config keywords
2557 - MINOR: filters: extend flt_dump_kws() to dump to stdout
2558 - MINOR: services: extend list_services() to dump to stdout
2559 - MINOR: cli: add a new keyword dump function
2560 - MINOR: acl: add a function to dump the list of known ACL keywords
2561 - MINOR: samples: add a function to list register sample fetch keywords
2562 - MINOR: sample: list registered sample converter functions
2563 - MINOR: tools: add strordered() to check whether strings are ordered
2564 - MINOR: action: add a function to dump the list of actions for a ruleset
2565 - MINOR: config: alphanumerically sort config keywords output
2566 - MINOR: sample: alphanumerically sort sample & conv keyword dumps
2567 - MINOR: acl: alphanumerically sort the ACL dump
2568 - MINOR: cli: alphanumerically sort the dump of supported commands
2569 - MINOR: filters: alphabetically sort the list of filter names
2570 - MINOR: services: alphabetically sort service names
2571 - MEDIUM: httpclient/lua: be stricter with httpclient parameters
2572 - MINOR: ssl: split the cert commit io handler
2573 - MINOR: ssl: move the cert_exts and the CERT_TYPE enum
2574 - MINOR: ssl: simplify the certificate extensions array
2575 - MINOR: ssl: export ckch_inst_rebuild()
2576 - MINOR: ssl: add "crt" in the cert_exts array
2577 - MINOR: ssl/lua: CertCache.set() allows to update an SSL certificate file
2578 - BUILD: ssl/lua: CacheCert needs OpenSSL
2579 - DOC: lua: CertCache class documentation
2580 - BUG/MEDIUM: quic: do not use qcs from quic_stream on ACK parsing
2581 - MINOR: mux-quic: return qcs instance from qcc_get_qcs
2582 - MINOR: mux-quic: reorganize qcs free
2583 - MINOR: mux-quic: define release app-ops
2584 - BUG/MINOR: h3: release resources on close
2585 - BUG/MINOR: mux-quic: ensure to free all qcs on MUX release
2586 - CLEANUP: quic: complete comment on qcs_try_to_consume
2587 - MINOR: quic: implement stream descriptor for transport layer
2588 - MEDIUM: quic: move transport fields from qcs to qc_conn_stream
2589 - MEDIUM: mux-quic: remove qcs tree node
2590 - BUG/MINOR: cli/stream: fix "shutdown session" to iterate over all threads
2591 - DOC: management: add missing dot in 9.4.1
2592 - BUG/MAJOR: mux_pt: always report the connection error to the conn_stream
2593 - DOC: remove double blanks in configuration.txt
2594 - CI: github actions: update OpenSSL to 3.0.2
2595 - BUG/MEDIUM: quic: Possible crash in ha_quic_set_encryption_secrets()
2596 - CLEANUP: quic: Remove all atomic operations on quic_conn struct
2597 - CLEANUP: quic: Remove all atomic operations on packet number spaces
2598 - MEDIUM: quic: Send ACK frames asap
2599 - BUG/MINOR: quic: Missing probing packets when coalescing
2600 - BUG/MINOR: quic: Discard Initial packet number space only one time
2601 - MINOR: quic: Do not display any timer value from process_timer()
2602 - BUG/MINOR: quic: Do not probe from an already probing packet number space
2603 - BUG/MINOR: quic: Non duplicated frames upon fast retransmission
2604 - BUG/MINOR: quic: Too much prepared retransmissions due to anti-amplification
2605 - MINOR: quic: Useless call to SSL_CTX_set_default_verify_paths()
2606 - MINOR: quic: Add traces about list of frames
2607 - BUG/MINOR: h3: Missing wait event struct field initialization
2608 - BUG/MINOR: quic: QUIC TLS secrets memory leak
2609 - BUG/MINOR: quic: Missing ACK range deallocations
2610 - BUG/MINOR: quic: Missing TX packet deallocations
2611 - CLEANUP: hpack: be careful about integer promotion from uint8_t
2612 - OPTIM: hpack: read 32 bits at once when possible.
2613 - MEDIUM: ssl: allow loading of a directory with the ca-file directive
2614 - BUG/MINOR: ssl: continue upon error when opening a directory w/ ca-file
2615 - MINOR: ssl: ca-file @system-ca loads the system trusted CA
2616 - DOC: configuration: add the ca-file changes
2617 - MINOR: sample: converter: Add add_item convertor
2618 - BUG/MINOR: ssl: handle X509_get_default_cert_dir() returning NULL
2619 - BUG/MINOR: ssl/cli: Remove empty lines from CLI output
2620 - MINOR: httpclient: enable request buffering
2621 - MEDIUM: httpclient: enable l7-retry
2622 - BUG/MINOR: httpclient: end callback in applet release
2623 - MINOR: quic: Add draining connection state.
2624 - MINOR: quic: Add closing connection state
2625 - BUG/MEDIUM: quic: ensure quic-conn survives to the MUX
2626 - CLEANUP: quic: use static qualifer on quic_close
2627 - CLEANUP: mux-quic: remove unused QC_CF_CC_RECV
2628 - BUG/MINOR: fix memleak on quic-conn streams cleaning
2629 - MINOR: mux-quic: factorize conn-stream attach
2630 - MINOR: mux-quic: adjust timeout to accelerate closing
2631 - MINOR: mux-quic: define is_active app-ops
2632 - MINOR: mux-quic: centralize send operations in qc_send
2633 - MEDIUM: mux-quic: report CO_FL_ERROR on send
2634 - MEDIUM: mux-quic: report errors on conn-streams
2635 - MEDIUM: quic: report closing state for the MUX
2636 - BUG/MINOR: fcgi-app: Don't add C-L header on response to HEAD requests
2637 - BUG/MEDIUM: stats: Be sure to never set EOM flag on an empty HTX message
2638 - BUG/MEDIUM: hlua: Don't set EOM flag on an empty HTX message in HTTP applet
2639 - BUG/MEDIUM: promex: Be sure to never set EOM flag on an empty HTX message
2640 - BUG/MEDIUM: mux-h1: Set outgoing message to DONE when payload length is reached
2641 - BUG/MINOR: http_client: Don't add input data on an empty request buffer
2642 - BUG/MEDIUM: http-conv: Fix url_enc() to not crush const samples
2643 - BUG/MEDIUM: http-act: Don't replace URI if path is not found or invalid
2644 - CLEANUP: mux-quic: remove uneeded TODO in qc_detach
2645 - BUG/MEDIUM: mux-quic: properly release conn-stream on detach
2646 - BUG/MINOR: quic: set the source not the destination address on accept()
2647 - BUG/MEDIUM: quic: Possible crash from quic_free_arngs()
2648 - MINOR: quic_tls: Add reusable cipher contexts to QUIC TLS contexts
2649 - MINOR: quic_tls: Stop hardcoding cipher IV lengths
2650 - CLEANUP: quic: Do not set any cipher/group from ssl_quic_initial_ctx()
2651 - MINOR: quic: Add short packet key phase bit values to traces
2652 - MINOR: quic_tls: Make key update use of reusable cipher contexts
2653 - BUG/MINOR: opentracing: setting the return value in function flt_ot_var_set()
2654 - BUG/BUILD: opentracing: fixed OT_DEFINE variable setting
2655 - EXAMPLES: opentracing: refined shell scripts for testing filter performance
2656 - DOC: opentracing: corrected comments in function descriptions
2657 - CLEANUP: opentracing: removed unused function flt_ot_var_unset()
2658 - CLEANUP: opentracing: removed unused function flt_ot_var_get()
2659 - Revert "MINOR: opentracing: change the scope of the variable 'ot.uuid' from 'sess' to 'txn'"
2660 - MINOR: opentracing: only takes the variables lock on shared entries
2661 - CLEANUP: opentracing: added flt_ot_smp_init() function
2662 - CLEANUP: opentracing: added variable to store variable length
2663 - MINOR: opentracing: improved normalization of context variable names
2664 - DEBUG: opentracing: show return values of all functions in the debug output
2665 - CLEANUP: opentracing: added FLT_OT_PARSE_INVALID_enum enum
2666 - DEBUG: opentracing: display the contents of the err variable after setting
2667 - MAJOR: opentracing: reenable usage of vars to transmit opentracing context
2668 - Revert "BUILD: opentracing: display warning in case of using OT_USE_VARS at compile time"
2669 - MEDIUM: global: Add a "close-spread-time" option to spread soft-stop on time window
2670
Willy Tarreau0541c2b2022-03-26 08:31:33 +010026712022/03/26 : 2.6-dev4
2672 - BUG/MEDIUM: httpclient: don't consume data before it was analyzed
2673 - CLEANUP: htx: remove unused co_htx_remove_blk()
2674 - BUG/MINOR: httpclient: consume partly the blocks when necessary
2675 - BUG/MINOR: httpclient: remove the UNUSED block when parsing headers
2676 - BUG/MEDIUM: httpclient: must manipulate head, not first
2677 - REGTESTS: fix the race conditions in be2hex.vtc
2678 - BUG/MEDIUM: quic: Blocked STREAM when retransmitted
2679 - BUG/MAJOR: quic: Possible crash with full congestion control window
2680 - BUG/MINOR: httpclient/lua: stuck when closing without data
2681 - BUG/MEDIUM: applet: Don't call .release callback function twice
2682 - BUG/MEDIUM: cli/debug: Properly get the stream-int in all debug I/O handlers
2683 - BUG/MEDIUM: sink: Properly get the stream-int in appctx callback functions
2684 - DEV: udp: switch parser to getopt() instead of positional arguments
2685 - DEV: udp: add support for random packet corruption
2686 - MINOR: server: export server_parse_sni_expr() function
2687 - BUG/MINOR: httpclient: send the SNI using the host header
2688 - BUILD: httpclient: fix build without SSL
2689 - BUG/MINOR: server/ssl: free the SNI sample expression
2690 - BUG/MINOR: logs: fix logsrv leaks on clean exit
2691 - MINOR: actions: add new function free_act_rule() to free a single rule
2692 - BUG/MINOR: tcp-rules: completely free incorrect TCP rules on error
2693 - BUG/MINOR: http-rules: completely free incorrect TCP rules on error
2694 - BUG/MINOR: httpclient: only check co_data() instead of HTTP_MSG_DATA
2695 - BUG/MINOR: httpclient: process the response when received before the end of the request
2696 - BUG/MINOR: httpclient: CF_SHUTW_NOW should be tested with channel_is_empty()
2697 - CI: github actions: switch to LibreSSL-3.5.1
2698 - BUG/MEDIUM: mux-h1: only turn CO_FL_ERROR to CS_FL_ERROR with empty ibuf
2699 - BUG/MEDIUM: stream-int: do not rely on the connection error once established
2700 - BUG/MEDIUM: trace: avoid race condition when retrieving session from conn->owner
2701 - MEDIUM: mux-h2: slightly relax timeout management rules
2702 - BUG/MEDIUM: mux-h2: make use of http-request and keep-alive timeouts
2703 - BUG/MINOR: rules: Initialize the list element when allocating a new rule
2704 - BUG/MINOR: http-rules: Don't free new rule on allocation failure
2705 - DEV: coccinelle: Fix incorrect replacement in ist.cocci
2706 - CLEANUP: Reapply ist.cocci with `--include-headers-for-types --recursive-includes`
2707 - DEV: coccinelle: Add a new pattern to ist.cocci
2708 - CLEANUP: Reapply ist.cocci
2709 - REGTESTS: Do not use REQUIRE_VERSION for HAProxy 2.5+
2710 - MINOR: quic: Code factorization (TX buffer reuse)
2711 - CLEANUP: quic: "largest_acked_pn" pktns struc member moving
2712 - MEDIUM: quic: Limit the number of ACK ranges
2713 - MEDIUM: quic: Rework of the TX packets memory handling
2714 - BUG/MINOR: quic: Possible crash in parse_retry_token()
2715 - BUG/MINOR: quic: Possible leak in quic_build_post_handshake_frames()
2716 - BUG/MINOR: quic: Unsent frame because of qc_build_frms()
2717 - BUG/MINOR: mux-quic: Access to empty frame list from qc_send_frames()
2718 - BUG/MINOR: mux-quic: Missing I/O handler events initialization
2719 - BUG/MINOR: quic: Missing TX packet initializations
2720 - BUG/MINOR: quic: 1RTT packets ignored after mux was released
2721 - BUG/MINOR: quic: Incorrect peer address validation
2722 - BUG/MINOR: quic: Non initialized variable in quic_build_post_handshake_frames()
2723 - BUG/MINOR: quic: Wrong TX packet related counters handling
2724 - MEDIUM: mqtt: support mqtt_is_valid and mqtt_field_value converters for MQTTv3.1
2725 - DOC: config: Explictly add supported MQTT versions
2726 - MINOR: quic: Add traces about stream TX buffer consumption
2727 - MINOR: quic: Add traces in qc_set_timer() (scheduling)
2728 - CLEANUP: mux-quic: change comment style to not mess with git conflict
2729 - CLEANUP: mux-quic: adjust comment for coding-style
2730 - MINOR: mux-quic: complete trace when stream is not found
2731 - MINOR: mux-quic: add comments for send functions
2732 - MINOR: mux-quic: use shorter name for flow-control fields
2733 - MEDIUM: mux-quic: respect peer bidirectional stream data limit
2734 - MEDIUM: mux-quic: respect peer connection data limit
2735 - MINOR: mux-quic: support MAX_STREAM_DATA frame parsing
2736 - MINOR: mux-quic: support MAX_DATA frame parsing
2737 - BUILD: stream-int: avoid a build warning when DEBUG is empty
2738 - BUG/MINOR: quic: Wrong buffer length passed to generate_retry_token()
2739 - BUG/MINOR: tools: fix url2sa return value with IPv4
2740 - MINOR: mux-quic: convert fin on push-frame as boolean
2741 - BUILD: quic: add missing includes
2742 - REORG: quic: use a dedicated quic_loss.c
2743 - MINOR: mux-quic: declare the qmux trace module
2744 - MINOR: mux-quic: replace printfs by traces
2745 - MINOR: mux-quic: add trace event for frame sending
2746 - MINOR: mux-quic: add trace event for qcs_push_frame
2747 - MINOR: mux-quic: activate qmux traces on stdout via macro
2748 - BUILD: qpack: fix unused value when not using DEBUG_HPACK
2749 - CLEANUP: qpack: suppress by default stdout traces
2750 - CLEANUP: h3: suppress by default stdout traces
2751 - BUG/MINOR: tools: url2sa reads too far when no port nor path
2752
Willy Tarreaubc8b7a12022-03-11 18:09:24 +010027532022/03/11 : 2.6-dev3
2754 - DEBUG: rename WARN_ON_ONCE() to CHECK_IF()
2755 - DEBUG: improve BUG_ON output message accuracy
2756 - DEBUG: implement 4 levels of choices between warn and crash.
2757 - DEBUG: add two new macros to enable debugging in hot paths
2758 - DEBUG: buf: replace some sensitive BUG_ON() with BUG_ON_HOT()
2759 - DEBUG: buf: add BUG_ON_HOT() to most buffer management functions
2760 - MINOR: channel: don't use co_set_data() to decrement output
2761 - DEBUG: channel: add consistency checks using BUG_ON_HOT() in some key functions
2762 - MINOR: conn-stream: Improve API to have safe/unsafe accessors
2763 - MEDIUM: tree-wide: Use unsafe conn-stream API when it is relevant
2764 - CLEANUP: stream-int: Make si_cs_send() function static
2765 - REORG: stream-int: Uninline si_sync_recv() and make si_cs_recv() private
2766 - BUG/MEDIUM: mux-fcgi: Don't rely on SI src/dst addresses for FCGI health-checks
2767 - BUG/MEDIUM: htx: Fix a possible null derefs in htx_xfer_blks()
2768 - REGTESTS: fix the race conditions in normalize_uri.vtc
2769 - DEBUG: stream-int: Fix BUG_ON used to test appctx in si_applet_ops callbacks
2770 - BUILD: debug: fix build warning on older compilers around DEBUG_STRICT_ACTION
2771 - CLEANUP: connection: Indicate unreachability to the compiler in conn_recv_proxy
2772 - MINOR: connection: Transform safety check in PROXYv2 parsing into BUG_ON()
2773 - DOC: install: it's DEBUG_CFLAGS, not DEBUG, which is set to -g
2774 - DOC: install: describe the DEP variable
2775 - DOC: install: describe how to choose options used in the DEBUG variable
2776 - MINOR: queue: Replace if() + abort() with BUG_ON()
2777 - CLEANUP: adjust indentation in bidir STREAM handling function
2778 - MINOR: quic: simplify copy of STREAM frames to RX buffer
2779 - MINOR: quic: handle partially received buffered stream frame
2780 - MINOR: mux-quic: define flag for last received frame
2781 - BUG/MINOR: quic: support FIN on Rx-buffered STREAM frames
2782 - MEDIUM: quic: rearchitecture Rx path for bidirectional STREAM frames
2783 - REGTESTS: fix the race conditions in secure_memcmp.vtc
2784 - CLEANUP: stream: Remove useless tests on conn-stream in stream_dump()
2785 - BUILD: ssl: another build warning on LIBRESSL_VERSION_NUMBER
2786 - MINOR: quic: Ensure PTO timer is not set in the past
2787 - MINOR: quic: Post handshake I/O callback switching
2788 - MINOR: quic: Drop the packets of discarded packet number spaces
2789 - CLEANUP: quic: Useless tests in qc_try_rm_hp()
2790 - CLEANUP: quic: Indentation fix in qc_prep_pkts()
2791 - MINOR: quic: Assemble QUIC TLS flags at the same level
2792 - BUILD: conn_stream: avoid null-deref warnings on gcc 6
2793 - BUILD: connection: do not declare register_mux_proto() inline
2794 - BUILD: http_rules: do not declare http_*_keywords_registre() inline
2795 - BUILD: trace: do not declare trace_registre_source() inline
2796 - BUILD: tcpcheck: do not declare tcp_check_keywords_register() inline
2797 - DEBUG: reduce the footprint of BUG_ON() calls
2798 - BUG/MEDIUM: httpclient/lua: infinite appctx loop with POST
2799 - BUG/MINOR: pool: always align pool_heads to 64 bytes
2800 - DEV: udp: add a tiny UDP proxy for testing
2801 - DEV: udp: implement pseudo-random reordering/loss
2802 - DEV: udp: add an optional argument to set the prng seed
2803 - BUG/MINOR: quic: fix segfault on CC if mux uninitialized
2804 - BUG/MEDIUM: pools: fix ha_free() on area in the process of being freed
2805 - CLEANUP: tree-wide: remove a few rare non-ASCII chars
2806 - CI: coverity: simplify debugging options
2807 - CLEANUP: quic: complete ABORT_NOW with a TODO comment
2808 - MINOR: quic: qc_prep_app_pkts() implementation
2809 - MINOR: quic: Send short packet from a frame list
2810 - MINOR: quic: Make qc_build_frms() build ack-eliciting frames from a list
2811 - MINOR: quic: Export qc_send_app_pkts()
2812 - MINOR: mux-quic: refactor transport parameters init
2813 - MINOR: mux-quic: complete functions to detect stream type
2814 - MINOR: mux-quic: define new unions for flow-control fields
2815 - MEDIUM: mux-quic: use direct send transport API for STREAMs
2816 - MINOR: mux-quic: retry send opportunistically for remaining frames
2817 - MEDIUM: mux-quic: implement MAX_STREAMS emission for bidir streams
2818 - BUILD: fix kFreeBSD build.
2819 - MINOR: quic: Retry on qc_build_pkt() failures
2820 - BUG/MINOR: quic: Missing recovery start timer reset
2821 - CLEANUP: quic: Remove QUIC path manipulations out of the congestion controller
2822 - MINOR: quic: Add a "slow start" callback to congestion controller
2823 - MINOR: quic: Persistent congestion detection outside of controllers
2824 - CLEANUP: quic: Remove useless definitions from quic_cc_event struct
2825 - BUG/MINOR: quic: Confusion betwen "in_flight" and "prep_in_flight" in quic_path_prep_data()
2826 - MINOR: quic: More precise window update calculation
2827 - CLEANUP: quic: Remove window redundant variable from NewReno algorithm state struct
2828 - MINOR: quic: Add quic_max_int_by_size() function
2829 - BUG/MAJOR: quic: Wrong quic_max_available_room() returned value
2830 - MINOR: pools: add a new global option "no-memory-trimming"
2831 - BUG/MINOR: add missing modes in proxy_mode_str()
2832 - BUG/MINOR: cli: shows correct mode in "show sess"
2833 - BUG/MEDIUM: quic: do not drop packet on duplicate stream/decoding error
2834 - MINOR: stats: Add dark mode support for socket rows
2835 - BUILD: fix recent build breakage of freebsd caused by kFreeBSD build fix
2836 - BUG/MINOR: httpclient: Set conn-stream/channel EOI flags at the end of request
2837 - BUG/MINOR: hlua: Set conn-stream/channel EOI flags at the end of request
2838 - BUG/MINOR: stats: Set conn-stream/channel EOI flags at the end of request
2839 - BUG/MINOR: cache: Set conn-stream/channel EOI flags at the end of request
2840 - BUG/MINOR: promex: Set conn-stream/channel EOI flags at the end of request
2841 - BUG/MEDIUM: stream: Use the front analyzers for new listener-less streams
2842 - DEBUG: cache: Update underlying buffer when loading HTX message in cache applet
2843 - BUG/MEDIUM: mcli: Properly handle errors and timeouts during reponse processing
2844 - DEBUG: stream: Add the missing descriptions for stream trace events
2845 - DEBUG: stream: Fix stream trace message to print response buffer state
2846 - MINOR: proxy: Store monitor_uri as a `struct ist`
2847 - MINOR: proxy: Store fwdfor_hdr_name as a `struct ist`
2848 - MINOR: proxy: Store orgto_hdr_name as a `struct ist`
2849 - MEDIUM: proxy: Store server_id_hdr_name as a `struct ist`
2850 - CLEANUP: fcgi: Replace memcpy() on ist by istcat()
2851 - CLEANUP: fcgi: Use `istadv()` in `fcgi_strm_send_params`
2852 - BUG/MAJOR: mux-pt: Always destroy the backend connection on detach
2853 - DOC: sample fetch methods: move distcc_* to the right locations
2854 - MINOR: rules: record the last http/tcp rule that gave a final verdict
2855 - MINOR: stream: add "last_rule_file" and "last_rule_line" samples
2856 - BUG/MINOR: session: fix theoretical risk of memleak in session_accept_fd()
2857 - MINOR: quic: Add max_idle_timeout advertisement handling
2858 - MEDIUM: quic: Remove the QUIC connection reference counter
2859 - BUG/MINOR: quic: ACK_REQUIRED and ACK_RECEIVED flag collision
2860 - BUG/MINOR: quic: Missing check when setting the anti-amplification limit as reached
2861 - MINOR: quic: Add a function to compute the current PTO
2862 - MEDIUM: quic: Implement the idle timeout feature
2863 - BUG/MEDIUM: quic: qc_prep_app_pkts() retries on qc_build_pkt() failures
2864 - CLEANUP: quic: Comments fix for qc_prep_(app)pkts() functions
2865 - MINOR: mux-quic: prevent push frame for unidir streams
2866 - MINOR: mux-quic: improve opportunistic retry sending for STREAM frames
2867 - MINOR: quic: implement sending confirmation
2868 - MEDIUM: mux-quic: improve bidir STREAM frames sending
2869 - MEDIUM: check: do not auto configure SSL/PROXY for dynamic servers
2870 - REGTESTS: server: test SSL/PROXY with checks for dynamic servers
2871 - MEDIUM: server: remove experimental-mode for dynamic servers
2872 - BUG/MINOR: buffer: fix debugging condition in b_peek_varint()
2873
Willy Tarreau3b1d1902022-02-25 17:12:11 +010028742022/02/25 : 2.6-dev2
2875 - DOC: management: rework the Master CLI section
2876 - DOC: management: add expert and experimental mode in 9.4.1
2877 - CLEANUP: cleanup a commentary in pcli_parse_request()
2878 - BUG/MINOR: mworker/cli: don't display help on master applet
2879 - MINOR: mworker/cli: mcli-debug-mode enables every command
2880 - MINOR: mworker/cli: add flags in the prompt
2881 - BUG/MINOR: httpclient: Revisit HC request and response buffers allocation
2882 - BUG/MEDIUM: httpclient: Xfer the request when the stream is created
2883 - MINOR: httpclient: Don't limit data transfer to 1024 bytes
2884 - BUILD: ssl: adjust guard for X509_get_X509_PUBKEY(x)
2885 - REGTESTS: ssl: skip show_ssl_ocspresponse.vtc when BoringSSL is used
2886 - MINOR: quic: Do not modify a marked as consumed datagram
2887 - MINOR: quic: Wrong datagram buffer passed to quic_lstnr_dgram_dispatch()
2888 - MINOR: quic: Remove a useless test in quic_get_dgram_dcid()
2889 - BUG/MINOR: ssl: Remove empty lines from "show ssl ocsp-response <id>" output
2890 - CLEANUP: ssl: Remove unused ssl_sock_create_cert function
2891 - MINOR: ssl: Use high level OpenSSL APIs in sha2 converter
2892 - MINOR: ssl: Remove EC_KEY related calls when preparing SSL context
2893 - REGTESTS: ssl: Add test for "curves" and "ecdhe" SSL options
2894 - MINOR: ssl: Remove EC_KEY related calls when creating a certificate
2895 - REGTESTS: ssl: Add test for "generate-certificates" SSL option
2896 - MINOR: ssl: Remove call to SSL_CTX_set_tlsext_ticket_key_cb with OpenSSLv3
2897 - MINOR: ssl: Remove call to HMAC_Init_ex with OpenSSLv3
2898 - MINOR: h3: hardcode the stream id of control stream
2899 - MINOR: mux-quic: remove quic_transport_params_update
2900 - MINOR: quic: rename local tid variable
2901 - MINOR: quic: remove unused xprt rcv_buf operation
2902 - MINOR: quic: take out xprt snd_buf operation
2903 - CI: enable QUIC for Coverity scan
2904 - BUG/MINOR: mworker: does not erase the pidfile upon reload
2905 - MINOR: ssl: Remove call to ERR_func_error_string with OpenSSLv3
2906 - MINOR: ssl: Remove call to ERR_load_SSL_strings with OpenSSLv3
2907 - REGTESTS: ssl: Add tests for DH related options
2908 - MINOR: ssl: Create HASSL_DH wrapper structure
2909 - MINOR: ssl: Add ssl_sock_get_dh_from_bio helper function
2910 - MINOR: ssl: Factorize ssl_get_tmp_dh and append a cbk to its name
2911 - MINOR: ssl: Add ssl_sock_set_tmp_dh helper function
2912 - MINOR: ssl: Add ssl_sock_set_tmp_dh_from_pkey helper function
2913 - MINOR: ssl: Add ssl_new_dh_fromdata helper function
2914 - MINOR: ssl: Build local DH of right size when needed
2915 - MINOR: ssl: Set default dh size to 2048
2916 - MEDIUM: ssl: Replace all DH objects by EVP_PKEY on OpenSSLv3 (via HASSL_DH type)
2917 - MINOR: ssl: Remove calls to SSL_CTX_set_tmp_dh_callback on OpenSSLv3
2918 - MINOR: quic: Remove an RX buffer useless lock
2919 - MINOR: quic: Variable used before being checked in ha_quic_add_handshake_data()
2920 - MINOR: quic: EINTR error ignored
2921 - MINOR: quic: Potential overflow expression in qc_parse_frm()
2922 - MINOR: quic: Possible overflow in qpack_get_varint()
2923 - CLEANUP: h3: Unreachable target in h3_uqs_init()
2924 - MINOR: quic: Possible memleak in qc_new_conn()
2925 - MINOR: quic: Useless statement in quic_crypto_data_cpy()
2926 - BUG/MEDIUM: pools: ensure items are always large enough for the pool_cache_item
2927 - BUG/MINOR: pools: always flush pools about to be destroyed
2928 - CLEANUP: pools: don't needlessly set a call mark during refilling of caches
2929 - DEBUG: pools: add extra sanity checks when picking objects from a local cache
2930 - DEBUG: pools: let's add reverse mapping from cache heads to thread and pool
2931 - DEBUG: pools: replace the link pointer with the caller's address on pool_free()
2932 - BUG/MAJOR: sched: prevent rare concurrent wakeup of multi-threaded tasks
2933 - MINOR: quic: use a global dghlrs for each thread
2934 - BUG/MEDIUM: quic: fix crash on CC if mux not present
2935 - MINOR: qpack: fix typo in trace
2936 - BUG/MINOR: quic: fix FIN stream signaling
2937 - BUG/MINOR: h3: fix the header length for QPACK decoding
2938 - MINOR: h3: remove transfer-encoding header
2939 - MINOR: h3: add documentation on h3_decode_qcs
2940 - MINOR: h3: set properly HTX EOM/BODYLESS on HEADERS parsing
2941 - MINOR: mux-quic: implement rcv_buf
2942 - MINOR: mux-quic: set EOS on rcv_buf
2943 - MINOR: h3: set CS_FL_NOT_FIRST
2944 - MINOR: h3: report frames bigger than rx buffer
2945 - MINOR: h3: extract HEADERS parsing in a dedicated function
2946 - MINOR: h3: implement DATA parsing
2947 - MINOR: quic: Wrong smoothed rtt initialization
2948 - MINOR: quic: Wrong loss delay computation
2949 - MINOR: quic: Code never reached in qc_ssl_sess_init()
2950 - MINOR: quic: ha_quic_set_encryption_secrets without server specific code
2951 - MINOR: quic: Avoid warning about NULL pointer dereferences
2952 - MINOR: quic: Useless test in quic_lstnr_dghdlr()
2953 - MINOR: quic: Non checked returned value for cs_new() in hq_interop_decode_qcs()
2954 - MINOR: h3: Dead code in h3_uqs_init()
2955 - MINOR: quic: Non checked returned value for cs_new() in h3_decode_qcs()
2956 - MINOR: quic: Possible frame parsers array overrun
2957 - MINOR: quic: Do not retransmit too much packets.
2958 - MINOR: quic: Move quic_rxbuf_pool pool out of xprt part
2959 - MINOR: h3: report error on HEADERS/DATA parsing
2960 - BUG/MINOR: jwt: Double free in deinit function
2961 - BUG/MINOR: jwt: Missing pkey free during cleanup
2962 - BUG/MINOR: jwt: Memory leak if same key is used in multiple jwt_verify calls
2963 - BUG/MINOR: httpclient/cli: display junk characters in vsn
2964 - MINOR: h3: remove unused return value on decode_qcs
2965 - BUG/MAJOR: http/htx: prevent unbounded loop in http_manage_server_side_cookies
2966 - BUG/MAJOR: spoe: properly detach all agents when releasing the applet
2967 - REGTESTS: server: close an occasional race on dynamic_server_ssl.vtc
2968 - REGTESTS: peers: leave a bit more time to peers to synchronize
2969 - BUG/MEDIUM: h2/hpack: fix emission of HPACK DTSU after settings change
2970 - BUG/MINOR: mux-h2: update the session's idle delay before creating the stream
2971 - BUG/MINOR: httpclient: reinit flags in httpclient_start()
2972 - BUG/MINOR: mailers: negotiate SMTP, not ESMTP
2973 - MINOR: httpclient: sets an alternative destination
2974 - MINOR: httpclient/lua: add 'dst' optionnal field
2975 - BUG/MINOR: ssl: Add missing return value check in ssl_ocsp_response_print
2976 - BUG/MINOR: ssl: Fix leak in "show ssl ocsp-response" CLI command
2977 - BUG/MINOR: ssl: Missing return value check in ssl_ocsp_response_print
2978 - CLEANUP: httpclient/cli: fix indentation alignment of the help message
2979 - BUG/MINOR: tools: url2sa reads ipv4 too far
2980 - BUG/MEDIUM: httpclient: limit transfers to the maximum available room
2981 - DEBUG: buffer: check in __b_put_blk() whether the buffer room is respected
2982 - MINOR: mux-quic: fix a possible null dereference in qc_timeout_task
2983 - BUG/MEDIUM: htx: Be sure to have a buffer to perform a raw copy of a message
2984 - BUG/MEDIUM: mux-h1: Don't wake h1s if mux is blocked on lack of output buffer
2985 - BUG/MAJOR: mux-h2: Be sure to always report HTX parsing error to the app layer
2986 - DEBUG: stream-int: Check CS_FL_WANT_ROOM is not set with an empty input buffer
2987 - MINOR: quic: do not modify offset node if quic_rx_strm_frm in tree
2988 - MINOR: h3: fix compiler warning variable set but not used
2989 - MINOR: mux-quic: fix uninitialized return on qc_send
2990 - MINOR: quic: fix handling of out-of-order received STREAM frames
2991 - MINOR: pools: mark most static pool configuration variables as read-mostly
2992 - CLEANUP: pools: remove the now unused pool_is_crowded()
2993 - REGTESTS: fix the race conditions in 40be_2srv_odd_health_checks
2994 - BUG/MEDIUM: stream: Abort processing if response buffer allocation fails
2995 - MINOR: httpclient/lua: ability to set a server timeout
2996 - BUG/MINOR: httpclient/lua: missing pop for new timeout parameter
2997 - DOC: httpclient/lua: fix the type of the dst parameter
2998 - CLEANUP: httpclient: initialize the client in stage INIT not REGISTER
2999 - CLEANUP: muxes: do not use a dynamic trash in list_mux_protos()
3000 - CLEANUP: vars: move the per-process variables initialization to vars.c
3001 - CLEANUP: init: remove the ifdef on HAPROXY_MEMMAX
3002 - MINOR: pools: disable redundant poisonning on pool_free()
3003 - MINOR: pools: introduce a new pool_debugging global variable
3004 - MINOR: pools: switch the fail-alloc test to runtime only
3005 - MINOR: pools: switch DEBUG_DONT_SHARE_POOLS to runtime
3006 - MINOR: pools: add a new debugging flag POOL_DBG_COLD_FIRST
3007 - MINOR: pools: add a new debugging flag POOL_DBG_INTEGRITY
3008 - MINOR: pools: make the global pools a runtime option.
3009 - MEDIUM: pools: replace CONFIG_HAP_POOLS with a runtime "NO_CACHE" flag.
3010 - MINOR: pools: store the allocated size for each pool
3011 - MINOR: pools: get rid of POOL_EXTRA
3012 - MINOR: pools: replace DEBUG_POOL_TRACING with runtime POOL_DBG_CALLER
3013 - MINOR: pools: replace DEBUG_MEMORY_POOLS with runtime POOL_DBG_TAG
3014 - MINOR: pools: add a debugging flag for memory poisonning option
3015 - MEDIUM: initcall: move STG_REGISTER earlier
3016 - MEDIUM: init: split the early initialization in its own function
3017 - MINOR: init: extract args parsing to their own function
3018 - MEDIUM: init: handle arguments earlier
3019 - MINOR: pools: delegate parsing of command line option -dM to a new function
3020 - MINOR: pools: support setting debugging options using -dM
3021 - BUILD: makefile: enable both DEBUG_STRICT and DEBUG_MEMORY_POOLS by default
3022 - CI: github: enable pool debugging by default
3023 - DOC: Fix usage/examples of deprecated ACLs
3024 - DOC: internal: update the pools API to mention boot-time settings
3025 - DOC: design: add design thoughts for later simplification of the pools
3026 - DOC: design: commit the temporary design notes on thread groups
3027 - MINOR: stream-int: Handle appctx case first when releasing the endpoint
3028 - MINOR: connection: Be prepared to handle conn-stream with no connection
3029 - MINOR: stream: Handle appctx case first when creating a new stream
3030 - MINOR: connection: Add a function to detach a conn-stream from the connection
3031 - MINOR: stream-int: Add function to reset a SI endpoint
3032 - MINOR: stream-int: Add function to attach a connection to a SI
3033 - MINOR: stream-int: Be able to allocate a CS without connection
3034 - MEDIUM: stream: No longer release backend conn-stream on connection retry
3035 - MEDIUM: stream: Allocate backend CS when the stream is created
3036 - REORG: conn_stream: move conn-stream stuff in dedicated files
3037 - MEDIUM: conn-stream: No longer access connection field directly
3038 - MEDIUM: conn-stream: Be prepared to use an appctx as conn-stream endpoint
3039 - MAJOR: conn_stream/stream-int: move the appctx to the conn-stream
3040 - MEDIUM: applet: Set the conn-stream as appctx owner instead of the stream-int
3041 - MEDIUM: conn_stream: Add a pointer to the app object into the conn-stream
3042 - MINOR: stream: Add pointer to front/back conn-streams into stream struct
3043 - MINOR: stream: Slightly rework stream_new to separate CS/SI initialization
3044 - MINOR: stream-int: Always access the stream-int via the conn-stream
3045 - MINOR: backend: Always access the stream-int via the conn-stream
3046 - MINOR: stream: Always access the stream-int via the conn-stream
3047 - MINOR: http-ana: Always access the stream-int via the conn-stream
3048 - MINOR: cli: Always access the stream-int via the conn-stream
3049 - MINOR: log: Always access the stream-int via the conn-stream
3050 - MINOR: frontend: Always access the stream-int via the conn-stream
3051 - MINOR: proxy: Always access the stream-int via the conn-stream
3052 - MINOR: peers: Always access the stream-int via the conn-stream
3053 - MINOR: debug: Always access the stream-int via the conn-stream
3054 - MINOR: hlua: Always access the stream-int via the conn-stream
3055 - MINOR: cache: Always access the stream-int via the conn-stream
3056 - MINOR: dns: Always access the stream-int via the conn-stream
3057 - MINOR: http-act: Always access the stream-int via the conn-stream
3058 - MINOR: httpclient: Always access the stream-int via the conn-stream
3059 - MINOR: tcp-act: Always access the stream-int via the conn-stream
3060 - MINOR: sink: Always access the stream-int via the conn-stream
3061 - MINOR: conn-stream: Rename cs_detach() to cs_detach_endp()
3062 - CLEANUP: conn-stream: Don't export conn-stream pool
3063 - MAJOR: stream/conn_stream: Move the stream-interface into the conn-stream
3064 - CLEANUP: stream-int: rename si_reset() to si_init()
3065 - MINOR: conn-stream: Release a CS when both app and endp are detached
3066 - MINOR: stream: Don't destroy conn-streams but detach app and endp
3067 - MAJOR: check: Use a persistent conn-stream for health-checks
3068 - CLEANUP: conn-stream: Remove cs_destroy()
3069 - CLEANUP: backend: Don't export connect_server anymore
3070 - BUG/MINOR: h3/hq_interop: Fix CS and stream creation
3071 - BUILD: tree-wide: Avoid warnings about undefined entities retrieved from a CS
3072 - BUG/MINOR: proxy: preset the error message pointer to NULL in parse_new_proxy()
3073 - BUG/MEDIUM: quic: fix received ACK stream calculation
3074 - BUILD: stream: fix build warning with older compilers
3075 - BUG/MINOR: debug: fix get_tainted() to properly read an atomic value
3076 - DEBUG: move the tainted stuff to bug.h for easier inclusion
3077 - DEBUG: cleanup back trace generation
3078 - DEBUG: cleanup BUG_ON() configuration
3079 - DEBUG: mark ABORT_NOW() as unreachable
3080 - DBEUG: add a new WARN_ON() macro
3081 - DEBUG: make the _BUG_ON() macro return the condition
3082 - DEBUG: add a new WARN_ON_ONCE() macro
3083 - DEBUG: report BUG_ON() and WARN_ON() in the tainted flags
3084 - MINOR: quic: adjust buffer handling for STREAM transmission
3085 - MINOR: quic: liberate the TX stream buffer after ACK processing
3086 - MINOR: quic: add a TODO for a memleak frame on ACK consume
3087
Willy Tarreau2454d6e2022-02-01 18:06:59 +010030882022/02/01 : 2.6-dev1
3089 - BUG/MINOR: cache: Fix loop on cache entries in "show cache"
3090 - BUG/MINOR: httpclient: allow to replace the host header
3091 - BUG/MINOR: lua: don't expose internal proxies
3092 - MEDIUM: mworker: seamless reload use the internal sockpairs
3093 - BUG/MINOR: lua: remove loop initial declarations
3094 - BUG/MINOR: mworker: does not add the -sf in wait mode
3095 - BUG/MEDIUM: mworker: FD leak of the eventpoll in wait mode
3096 - MINOR: quic: do not reject PADDING followed by other frames
3097 - REORG: quic: add comment on rare thread concurrence during CID alloc
3098 - CLEANUP: quic: add comments on CID code
3099 - MEDIUM: quic: handle CIDs to rattach received packets to connection
3100 - MINOR: qpack: support litteral field line with non-huff name
3101 - MINOR: quic: activate QUIC traces at compilation
3102 - MINOR: quic: use more verbose QUIC traces set at compile-time
3103 - MEDIUM: pool: refactor malloc_trim/glibc and jemalloc api addition detections.
3104 - MEDIUM: pool: support purging jemalloc arenas in trim_all_pools()
3105 - BUG/MINOR: mworker: deinit of thread poller was called when not initialized
3106 - BUILD: pools: only detect link-time jemalloc on ELF platforms
3107 - CI: github actions: add the output of $CC -dM -E-
3108 - BUG/MEDIUM: cli: Properly set stream analyzers to process one command at a time
3109 - BUILD: evports: remove a leftover from the dead_fd cleanup
3110 - MINOR: quic: Set "no_application_protocol" alert
3111 - MINOR: quic: More accurate immediately close.
3112 - MINOR: quic: Immediately close if no transport parameters extension found
3113 - MINOR: quic: Rename qc_prep_hdshk_pkts() to qc_prep_pkts()
3114 - MINOR: quic: Possible crash when inspecting the xprt context
3115 - MINOR: quic: Dynamically allocate the secrete keys
3116 - MINOR: quic: Add a function to derive the key update secrets
3117 - MINOR: quic: Add structures to maintain key phase information
3118 - MINOR: quic: Optional header protection key for quic_tls_derive_keys()
3119 - MINOR: quic: Add quic_tls_key_update() function for Key Update
3120 - MINOR: quic: Enable the Key Update process
3121 - MINOR: quic: Delete the ODCIDs asap
3122 - BUG/MINOR: vars: Fix the set-var and unset-var converters
3123 - MEDIUM: pool: Following up on previous pool trimming update.
3124 - BUG/MEDIUM: mux-h1: Fix splicing by properly detecting end of message
3125 - BUG/MINOR: mux-h1: Fix splicing for messages with unknown length
3126 - MINOR: mux-h1: Improve H1 traces by adding info about http parsers
3127 - MINOR: mux-h1: register a stats module
3128 - MINOR: mux-h1: add counters instance to h1c
3129 - MINOR: mux-h1: count open connections/streams on stats
3130 - MINOR: mux-h1: add stat for total count of connections/streams
3131 - MINOR: mux-h1: add stat for total amount of bytes received and sent
3132 - REGTESTS: h1: Add a script to validate H1 splicing support
3133 - BUG/MINOR: server: Don't rely on last default-server to init server SSL context
3134 - BUG/MEDIUM: resolvers: Detach query item on response error
3135 - MEDIUM: resolvers: No longer store query items in a list into the response
3136 - BUG/MAJOR: segfault using multiple log forward sections.
3137 - BUG/MEDIUM: h1: Properly reset h1m flags when headers parsing is restarted
3138 - BUG/MINOR: resolvers: Don't overwrite the error for invalid query domain name
3139 - BUILD: bug: Fix error when compiling with -DDEBUG_STRICT_NOCRASH
3140 - BUG/MEDIUM: sample: Fix memory leak in sample_conv_jwt_member_query
3141 - DOC: spoe: Clarify use of the event directive in spoe-message section
3142 - DOC: config: Specify %Ta is only available in HTTP mode
3143 - BUILD: tree-wide: avoid warnings caused by redundant checks of obj_types
3144 - IMPORT: slz: use the correct CRC32 instruction when running in 32-bit mode
3145 - MINOR: quic: fix segfault on CONNECTION_CLOSE parsing
3146 - MINOR: h3: add BUG_ON on control receive function
3147 - MEDIUM: xprt-quic: finalize app layer initialization after ALPN nego
3148 - MINOR: h3: remove duplicated FIN flag position
3149 - MAJOR: mux-quic: implement a simplified mux version
3150 - MEDIUM: mux-quic: implement release mux operation
3151 - MEDIUM: quic: detect the stream FIN
3152 - MINOR: mux-quic: implement subscribe on stream
3153 - MEDIUM: mux-quic: subscribe on xprt if remaining data after send
3154 - MEDIUM: mux-quic: wake up xprt on data transferred
3155 - MEDIUM: mux-quic: handle when sending buffer is full
3156 - MINOR: quic: RX buffer full due to wrong CRYPTO data handling
3157 - MINOR: quic: Race issue when consuming RX packets buffer
3158 - MINOR: quic: QUIC encryption level RX packets race issue
3159 - MINOR: quic: Delete remaining RX handshake packets
3160 - MINOR: quic: Remove QUIC TX packet length evaluation function
3161 - MINOR: hq-interop: fix tx buffering
3162 - MINOR: mux-quic: remove uneeded code to check fin on TX
3163 - MINOR: quic: add HTX EOM on request end
3164 - BUILD: mux-quic: fix compilation with DEBUG_MEM_STATS
3165 - MINOR: http-rules: Add capture action to http-after-response ruleset
3166 - BUG/MINOR: cli/server: Don't crash when a server is added with a custom id
3167 - MINOR: mux-quic: do not release qcs if there is remaining data to send
3168 - MINOR: quic: notify the mux on CONNECTION_CLOSE
3169 - BUG/MINOR: mux-quic: properly initialize flow control
3170 - MINOR: quic: Compilation fix for quic_rx_packet_refinc()
3171 - MINOR: h3: fix possible invalid dereference on htx parsing
3172 - DOC: config: retry-on list is space-delimited
3173 - DOC: config: fix error-log-format example
3174 - BUG/MEDIUM: mworker/cli: crash when trying to access an old PID in prompt mode
3175 - MINOR: hq-interop: refix tx buffering
3176 - REGTESTS: ssl: use X509_V_ERR_UNABLE_TO_GET_ISSUER_CERT_LOCALLY for cert check
3177 - MINOR: cli: "show version" displays the current process version
3178 - CLEANUP: cfgparse: modify preprocessor guards around numa detection code
3179 - MEDIUM: cfgparse: numa detect topology on FreeBSD.
3180 - BUILD: ssl: unbreak the build with newer libressl
3181 - MINOR: vars: Move UPDATEONLY flag test to vars_set_ifexist
3182 - MINOR: vars: Set variable type to ANY upon creation
3183 - MINOR: vars: Delay variable content freeing in var_set function
3184 - MINOR: vars: Parse optional conditions passed to the set-var converter
3185 - MINOR: vars: Parse optional conditions passed to the set-var actions
3186 - MEDIUM: vars: Enable optional conditions to set-var converter and actions
3187 - DOC: vars: Add documentation about the set-var conditions
3188 - REGTESTS: vars: Add new test for conditional set-var
3189 - MINOR: quic: Attach timer task to thread for the connection.
3190 - CLEANUP: quic_frame: Remove a useless suffix to STOP_SENDING
3191 - MINOR: quic: Add traces for STOP_SENDING frame and modify others
3192 - CLEANUP: quic: Remove cdata_len from quic_tx_packet struct
3193 - MINOR: quic: Enable TLS 0-RTT if needed
3194 - MINOR: quic: No TX secret at EARLY_DATA encryption level
3195 - MINOR: quic: Add quic_set_app_ops() function
3196 - MINOR: ssl_sock: Set the QUIC application from ssl_sock_advertise_alpn_protos.
3197 - MINOR: quic: Make xprt support 0-RTT.
3198 - MINOR: qpack: Missing check for truncated QPACK fields
3199 - CLEANUP: quic: Comment fix for qc_strm_cpy()
3200 - MINOR: hq_interop: Stop BUG_ON() truncated streams
3201 - MINOR: quic: Do not mix packet number space and connection flags
3202 - CLEANUP: quic: Shorten a litte bit the traces in lstnr_rcv_pkt()
3203 - MINOR: mux-quic: fix trace on stream creation
3204 - CLEANUP: quic: fix spelling mistake in a trace
3205 - CLEANUP: quic: rename quic_conn conn to qc in quic_conn_free
3206 - MINOR: quic: add missing lock on cid tree
3207 - MINOR: quic: rename constant for haproxy CIDs length
3208 - MINOR: quic: refactor concat DCID with address for Initial packets
3209 - MINOR: quic: compare coalesced packets by DCID
3210 - MINOR: quic: refactor DCID lookup
3211 - MINOR: quic: simplify the removal from ODCID tree
3212 - REGTESTS: vars: Remove useless ssl tunes from conditional set-var test
3213 - MINOR: ssl: Remove empty lines from "show ssl ocsp-response" output
3214 - MINOR: quic: Increase the RX buffer for each connection
3215 - MINOR: quic: Add a function to list remaining RX packets by encryption level
3216 - MINOR: quic: Stop emptying the RX buffer asap.
3217 - MINOR: quic: Do not expect to receive only one O-RTT packet
3218 - MINOR: quic: Do not forget STREAM frames received in disorder
3219 - MINOR: quic: Wrong packet refcount handling in qc_pkt_insert()
3220 - DOC: fix misspelled keyword "resolve_retries" in resolvers
3221 - CLEANUP: quic: rename quic_conn instances to qc
3222 - REORG: quic: move mux function outside of xprt
3223 - MINOR: quic: add reference to quic_conn in ssl context
3224 - MINOR: quic: add const qualifier for traces function
3225 - MINOR: trace: add quic_conn argument definition
3226 - MINOR: quic: use quic_conn as argument to traces
3227 - MINOR: quic: add quic_conn instance in traces for qc_new_conn
3228 - MINOR: quic: Add stream IDs to qcs_push_frame() traces
3229 - MINOR: quic: unchecked qc_retrieve_conn_from_cid() returned value
3230 - MINOR: quic: Wrong dropped packet skipping
3231 - MINOR: quic: Handle the cases of overlapping STREAM frames
3232 - MINOR: quic: xprt traces fixes
3233 - MINOR: quic: Drop asap Retry or Version Negotiation packets
3234 - MINOR: pools: work around possibly slow malloc_trim() during gc
3235 - DEBUG: ssl: make sure we never change a servername on established connections
3236 - MINOR: quic: Add traces for RX frames (flow control related)
3237 - MINOR: quic: Add CONNECTION_CLOSE phrase to trace
3238 - REORG: quic: remove qc_ prefix on functions which not used it directly
3239 - BUG/MINOR: quic: upgrade rdlock to wrlock for ODCID removal
3240 - MINOR: quic: remove unnecessary call to free_quic_conn_cids()
3241 - MINOR: quic: store ssl_sock_ctx reference into quic_conn
3242 - MINOR: quic: remove unnecessary if in qc_pkt_may_rm_hp()
3243 - MINOR: quic: replace usage of ssl_sock_ctx by quic_conn
3244 - MINOR: quic: delete timer task on quic_close()
3245 - MEDIUM: quic: implement refcount for quic_conn
3246 - BUG/MINOR: quic: fix potential null dereference
3247 - BUG/MINOR: quic: fix potential use of uninit pointer
3248 - BUG/MEDIUM: backend: fix possible sockaddr leak on redispatch
3249 - BUG/MEDIUM: peers: properly skip conn_cur from incoming messages
3250 - CI: Github Actions: do not show VTest failures if build failed
3251 - BUILD: opentracing: display warning in case of using OT_USE_VARS at compile time
3252 - MINOR: compat: detect support for dl_iterate_phdr()
3253 - MINOR: debug: add ability to dump loaded shared libraries
3254 - MINOR: debug: add support for -dL to dump library names at boot
3255 - BUG/MEDIUM: ssl: initialize correctly ssl w/ default-server
3256 - REGTESTS: ssl: fix ssl_default_server.vtc
3257 - BUG/MINOR: ssl: free the fields in srv->ssl_ctx
3258 - BUG/MEDIUM: ssl: free the ckch instance linked to a server
3259 - REGTESTS: ssl: update of a crt with server deletion
3260 - BUILD/MINOR: cpuset FreeBSD 14 build fix.
3261 - MINOR: pools: always evict oldest objects first in pool_evict_from_local_cache()
3262 - DOC: pool: document the purpose of various structures in the code
3263 - CLEANUP: pools: do not use the extra pointer to link shared elements
3264 - CLEANUP: pools: get rid of the POOL_LINK macro
3265 - MINOR: pool: allocate from the shared cache through the local caches
3266 - CLEANUP: pools: group list updates in pool_get_from_cache()
3267 - MINOR: pool: rely on pool_free_nocache() in pool_put_to_shared_cache()
3268 - MINOR: pool: make pool_is_crowded() always true when no shared pools are used
3269 - MINOR: pool: check for pool's fullness outside of pool_put_to_shared_cache()
3270 - MINOR: pool: introduce pool_item to represent shared pool items
3271 - MINOR: pool: add a function to estimate how many may be released at once
3272 - MEDIUM: pool: compute the number of evictable entries once per pool
3273 - MINOR: pools: prepare pool_item to support chained clusters
3274 - MINOR: pools: pass the objects count to pool_put_to_shared_cache()
3275 - MEDIUM: pools: centralize cache eviction in a common function
3276 - MEDIUM: pools: start to batch eviction from local caches
3277 - MEDIUM: pools: release cached objects in batches
3278 - OPTIM: pools: reduce local pool cache size to 512kB
3279 - CLEANUP: assorted typo fixes in the code and comments This is 29th iteration of typo fixes
3280 - CI: github actions: update OpenSSL to 3.0.1
3281 - BUILD/MINOR: tools: solaris build fix on dladdr.
3282 - BUG/MINOR: cli: fix _getsocks with musl libc
3283 - BUG/MEDIUM: http-ana: Preserve response's FLT_END analyser on L7 retry
3284 - MINOR: quic: Wrong traces after rework
3285 - MINOR: quic: Add trace about in flight bytes by packet number space
3286 - MINOR: quic: Wrong first packet number space computation
3287 - MINOR: quic: Wrong packet number space computation for PTO
3288 - MINOR: quic: Wrong loss time computation in qc_packet_loss_lookup()
3289 - MINOR: quic: Wrong ack_delay compution before calling quic_loss_srtt_update()
3290 - MINOR: quic: Remove nb_pto_dgrams quic_conn struct member
3291 - MINOR: quic: Wrong packet number space trace in qc_prep_pkts()
3292 - MINOR: quic: Useless test in qc_prep_pkts()
3293 - MINOR: quic: qc_prep_pkts() code moving
3294 - MINOR: quic: Speeding up Handshake Completion
3295 - MINOR: quic: Probe Initial packet number space more often
3296 - MINOR: quic: Probe several packet number space upon timer expiration
3297 - MINOR: quic: Comment fix.
3298 - MINOR: quic: Improve qc_prep_pkts() flexibility
3299 - MINOR: quic: Do not drop secret key but drop the CRYPTO data
3300 - MINOR: quic: Prepare Handshake packets asap after completed handshake
3301 - MINOR: quic: Flag asap the connection having reached the anti-amplification limit
3302 - MINOR: quic: PTO timer too often reset
3303 - MINOR: quic: Re-arm the PTO timer upon datagram receipt
3304 - MINOR: proxy: add option idle-close-on-response
3305 - MINOR: cpuset: switch to sched_setaffinity for FreeBSD 14 and above.
3306 - CI: refactor spelling check
3307 - CLEANUP: assorted typo fixes in the code and comments
3308 - BUILD: makefile: add -Wno-atomic-alignment to work around clang abusive warning
3309 - MINOR: quic: Only one CRYPTO frame by encryption level
3310 - MINOR: quic: Missing retransmission from qc_prep_fast_retrans()
3311 - MINOR: quic: Non-optimal use of a TX buffer
3312 - BUG/MEDIUM: mworker: don't use _getsocks in wait mode
3313 - BUG/MINOR: ssl: Store client SNI in SSL context in case of ClientHello error
3314 - BUG/MAJOR: mux-h1: Don't decrement .curr_len for unsent data
3315 - DOC: internals: document the pools architecture and API
3316 - CI: github actions: clean default step conditions
3317 - BUILD: cpuset: fix build issue on macos introduced by previous change
3318 - MINOR: quic: Remaining TRACEs with connection as firt arg
3319 - MINOR: quic: Reset ->conn quic_conn struct member when calling qc_release()
3320 - MINOR: quic: Flag the connection as being attached to a listener
3321 - MINOR: quic: Wrong CRYPTO frame concatenation
3322 - MINOR: quid: Add traces quic_close() and quic_conn_io_cb()
3323 - REGTESTS: ssl: Fix ssl_errors regtest with OpenSSL 1.0.2
3324 - MINOR: quic: Do not dereference ->conn quic_conn struct member
3325 - MINOR: quic: fix return of quic_dgram_read
3326 - MINOR: quic: add config parse source file
3327 - MINOR: quic: implement Retry TLS AEAD tag generation
3328 - MEDIUM: quic: implement Initial token parsing
3329 - MINOR: quic: define retry_source_connection_id TP
3330 - MEDIUM: quic: implement Retry emission
3331 - MINOR: quic: free xprt tasklet on its thread
3332 - BUG/MEDIUM: connection: properly leave stopping list on error
3333 - MINOR: pools: enable pools with DEBUG_FAIL_ALLOC as well
3334 - MINOR: quic: As server, skip 0-RTT packet number space
3335 - MINOR: quic: Do not wakeup the I/O handler before the mux is started
3336 - BUG/MEDIUM: htx: Adjust length to add DATA block in an empty HTX buffer
3337 - CI: github actions: use cache for OpenTracing
3338 - BUG/MINOR: httpclient: don't send an empty body
3339 - BUG/MINOR: httpclient: set default Accept and User-Agent headers
3340 - BUG/MINOR: httpclient/lua: don't pop the lua stack when getting headers
3341 - BUILD/MINOR: fix solaris build with clang.
3342 - BUG/MEDIUM: server: avoid changing healthcheck ctx with set server ssl
3343 - CI: refactor OpenTracing build script
3344 - DOC: management: mark "set server ssl" as deprecated
3345 - MEDIUM: cli: yield between each pipelined command
3346 - MINOR: channel: add new function co_getdelim() to support multiple delimiters
3347 - BUG/MINOR: cli: avoid O(bufsize) parsing cost on pipelined commands
3348 - MEDIUM: h2/hpack: emit a Dynamic Table Size Update after settings change
3349 - MINOR: quic: Retransmit the TX frames in the same order
3350 - MINOR: quic: Remove the packet number space TX MT_LIST
3351 - MINOR: quic: Splice the frames which could not be added to packets
3352 - MINOR: quic: Add the number of TX bytes to traces
3353 - CLEANUP: quic: Replace <nb_pto_dgrams> by <probe>
3354 - MINOR: quic: Send two ack-eliciting packets when probing packet number spaces
3355 - MINOR: quic: Probe regardless of the congestion control
3356 - MINOR: quic: Speeding up handshake completion
3357 - MINOR: quic: Release RX Initial packets asap
3358 - MINOR: quic: Release asap TX frames to be transmitted
3359 - MINOR: quic: Probe even if coalescing
3360 - BUG/MEDIUM: cli: Never wait for more data on client shutdown
3361 - BUG/MEDIUM: mcli: do not try to parse empty buffers
3362 - BUG/MEDIUM: mcli: always realign wrapping buffers before parsing them
3363 - BUG/MINOR: stream: make the call_rate only count the no-progress calls
3364 - MINOR: quic: do not use quic_conn after dropping it
3365 - MINOR: quic: adjust quic_conn refcount decrement
3366 - MINOR: quic: fix race-condition on xprt tasklet free
3367 - MINOR: quic: free SSL context on quic_conn free
3368 - MINOR: quic: Add QUIC_FT_RETIRE_CONNECTION_ID parsing case
3369 - MINOR: quic: Wrong packet number space selection
3370 - DEBUG: pools: add new build option DEBUG_POOL_INTEGRITY
3371 - MINOR: quic: add missing include in quic_sock
3372 - MINOR: quic: fix indentation in qc_send_ppkts
3373 - MINOR: quic: remove dereferencement of connection when possible
3374 - MINOR: quic: set listener accept cb on parsing
3375 - MEDIUM: quic/ssl: add new ex data for quic_conn
3376 - MINOR: quic: initialize ssl_sock_ctx alongside the quic_conn
3377 - MINOR: ssl: fix build in release mode
3378 - MINOR: pools: partially uninline pool_free()
3379 - MINOR: pools: partially uninline pool_alloc()
3380 - MINOR: pools: prepare POOL_EXTRA to be split into multiple extra fields
3381 - MINOR: pools: extend pool_cache API to pass a pointer to a caller
3382 - DEBUG: pools: add new build option DEBUG_POOL_TRACING
3383 - DEBUG: cli: add a new "debug dev fd" expert command
3384 - MINOR: fd: register the write side of the poller pipe as well
3385 - CI: github actions: use cache for SSL libs
3386 - BUILD: debug/cli: condition test of O_ASYNC to its existence
3387 - BUILD: pools: fix build error on DEBUG_POOL_TRACING
3388 - MINOR: quic: refactor header protection removal
3389 - MINOR: quic: handle app data according to mux/connection layer status
3390 - MINOR: quic: refactor app-ops initialization
3391 - MINOR: receiver: define a flag for local accept
3392 - MEDIUM: quic: flag listener for local accept
3393 - MINOR: quic: do not manage connection in xprt snd_buf
3394 - MINOR: quic: remove wait handshake/L6 flags on init connection
3395 - MINOR: listener: add flags field
3396 - MINOR: quic: define QUIC flag on listener
3397 - MINOR: quic: create accept queue for QUIC connections
3398 - MINOR: listener: define per-thr struct
3399 - MAJOR: quic: implement accept queue
3400 - CLEANUP: mworker: simplify mworker_free_child()
3401 - BUILD/DEBUG: lru: update the standalone code to support the revision
3402 - DEBUG: lru: use a xorshift generator in the testing code
3403 - BUG/MAJOR: compiler: relax alignment constraints on certain structures
3404 - BUG/MEDIUM: fd: always align fdtab[] to 64 bytes
3405 - MINOR: quic: No DCID length for datagram context
3406 - MINOR: quic: Comment fix about the token found in Initial packets
3407 - MINOR: quic: Get rid of a struct buffer in quic_lstnr_dgram_read()
3408 - MINOR: quic: Remove the QUIC haproxy server packet parser
3409 - MINOR: quic: Add new defintion about DCIDs offsets
3410 - MINOR: quic: Add a list to QUIC sock I/O handler RX buffer
3411 - MINOR: quic: Allocate QUIC datagrams from sock I/O handler
3412 - MINOR: proto_quic: Allocate datagram handlers
3413 - MINOR: quic: Pass CID as a buffer to quic_get_cid_tid()
3414 - MINOR: quic: Convert quic_dgram_read() into a task
3415 - CLEANUP: quic: Remove useless definition
3416 - MINOR: proto_quic: Wrong allocations for TX rings and RX bufs
3417 - MINOR: quic: Do not consume the RX buffer on QUIC sock i/o handler side
3418 - MINOR: quic: Do not reset a full RX buffer
3419 - MINOR: quic: Attach all the CIDs to the same connection
3420 - MINOR: quic: Make usage of by datagram handler trees
3421 - MEDIUM: da: new optional data file download scheduler service.
3422 - MEDIUM: da: update doc and build for new scheduler mode service.
3423 - MEDIUM: da: update module to handle schedule mode.
3424 - MINOR: quic: Drop Initial packets with wrong ODCID
3425 - MINOR: quic: Wrong RX buffer tail handling when no more contiguous data
3426 - MINOR: quic: Iterate over all received datagrams
3427 - MINOR: quic: refactor quic CID association with threads
3428 - BUG/MEDIUM: resolvers: Really ignore trailing dot in domain names
3429 - DEV: flags: Add missing flags
3430 - BUG/MINOR: sink: Use the right field in appctx context in release callback
3431 - MINOR: sock: move the unused socket cleaning code into its own function
3432 - BUG/MEDIUM: mworker: close unused transferred FDs on load failure
3433 - BUILD: atomic: make the old HA_ATOMIC_LOAD() support const pointers
3434 - BUILD: cpuset: do not use const on the source of CPU_AND/CPU_ASSIGN
3435 - BUILD: checks: fix inlining issue on set_srv_agent_[addr,port}
3436 - BUILD: vars: avoid overlapping field initialization
3437 - BUILD: server-state: avoid using not-so-portable isblank()
3438 - BUILD: mux_fcgi: avoid aliasing of a const struct in traces
3439 - BUILD: tree-wide: mark a few numeric constants as explicitly long long
3440 - BUILD: tools: fix warning about incorrect cast with dladdr1()
3441 - BUILD: task: use list_to_mt_list() instead of casting list to mt_list
3442 - BUILD: mworker: include tools.h for platforms without unsetenv()
3443 - BUG/MINOR: mworker: fix a FD leak of a sockpair upon a failed reload
3444 - MINOR: mworker: set the master side of ipc_fd in the worker to -1
3445 - MINOR: mworker: allocate and initialize a mworker_proc
3446 - CI: Consistently use actions/checkout@v2
3447 - REGTESTS: Remove REQUIRE_VERSION=1.8 from all tests
3448 - MINOR: mworker: sets used or closed worker FDs to -1
3449 - MINOR: quic: Try to accept 0-RTT connections
3450 - MINOR: quic: Do not try to treat 0-RTT packets without started mux
3451 - MINOR: quic: Do not try to accept a connection more than one time
3452 - MINOR: quic: Initialize the connection timer asap
3453 - MINOR: quic: Do not use connection struct xprt_ctx too soon
3454 - Revert "MINOR: mworker: sets used or closed worker FDs to -1"
3455 - BUILD: makefile: avoid testing all -Wno-* options when not needed
3456 - BUILD: makefile: validate support for extra warnings by batches
3457 - BUILD: makefile: only compute alternative options if required
3458 - DEBUG: fd: make sure we never try to insert/delete an impossible FD number
3459 - MINOR: mux-quic: add comment
3460 - MINOR: mux-quic: properly initialize qcc flags
3461 - MINOR: mux-quic: do not consider CONNECTION_CLOSE for the moment
3462 - MINOR: mux-quic: create a timeout task
3463 - MEDIUM: mux-quic: delay the closing with the timeout
3464 - MINOR: mux-quic: release idle conns on process stopping
3465 - MINOR: listener: replace the listener's spinlock with an rwlock
3466 - BUG/MEDIUM: listener: read-lock the listener during accept()
3467 - MINOR: mworker/cli: set expert/experimental mode from the CLI
3468
Willy Tarreau73dec762021-11-23 15:50:11 +010034692021/11/23 : 2.6-dev0
3470 - MINOR: version: it's development again
3471
Willy Tarreauf2e08332021-11-23 15:40:21 +010034722021/11/23 : 2.5.0
3473 - BUILD: SSL: add quictls build to scripts/build-ssl.sh
3474 - BUILD: SSL: add QUICTLS to build matrix
3475 - CLEANUP: sock: Wrap `accept4_broken = 1` into additional parenthesis
3476 - BUILD: cli: clear a maybe-unused warning on some older compilers
3477 - BUG/MEDIUM: cli: make sure we can report a warning from a bind keyword
3478 - BUG/MINOR: ssl: make SSL counters atomic
3479 - CLEANUP: assorted typo fixes in the code and comments
3480 - BUG/MINOR: ssl: free correctly the sni in the backend SSL cache
3481 - MINOR: version: mention that it's stable now
3482
Willy Tarreaua99cdfb2021-11-19 19:30:04 +010034832021/11/19 : 2.5-dev15
3484 - BUG/MINOR: stick-table/cli: Check for invalid ipv6 key
3485 - CLEANUP: peers: Remove useless test on peer variable in peer_trace()
3486 - DOC: log: Add comments to specify when session's listener is defined or not
3487 - BUG/MEDIUM: mux-h1: Handle delayed silent shut in h1_process() to release H1C
3488 - REGTESTS: ssl_crt-list_filters: feature cmd incorrectly set
3489 - DOC: internals: document the list API
3490 - BUG/MINOR: h3: ignore unknown frame types
3491 - MINOR: quic: redirect app_ops snd_buf through mux
3492 - MEDIUM: quic: inspect ALPN to install app_ops
3493 - MINOR: quic: support hq-interop
3494 - MEDIUM: quic: send version negotiation packet on unknown version
3495 - BUG/MEDIUM: mworker: cleanup the listeners when reexecuting
3496 - DOC: internals: document the scheduler API
3497 - BUG/MINOR: quic: fix version negotiation packet generation
3498 - CLEANUP: ssl: fix wrong #else commentary
3499 - MINOR: config: support default values for environment variables
3500 - SCRIPTS: run-regtests: reduce the number of processes needed to check options
3501 - SCRIPT: run-regtests: avoid several calls to grep to test for features
3502 - SCRIPT: run-regtests: avoid calling awk to compute the version
3503 - REGTEST: set retries count to zero for all tests that expect at 503
3504 - REGTESTS: make tcp-check_min-recv fail fast
3505 - REGTESTS: extend the default I/O timeouts and make them overridable
3506 - BUG/MEDIUM: ssl: backend TLS resumption with sni and TLSv1.3
3507 - BUG/MEDIUM: ssl: abort with the correct SSL error when SNI not found
3508 - REGTESTS: ssl: test the TLS resumption
3509 - BUILD: makefile: stop opening sub-shells for each and every command
3510 - BUILD: makefile: reorder objects by build time
3511 - BUG/MEDIUM: mux-h2: always process a pending shut read
3512 - MINOR: quic_sock: missing CO_FL_ADDR_TO_SET flag
3513 - MINOR: quic: Possible wrong connection identification
3514 - MINOR: quic: Correctly pad UDP datagrams
3515 - MINOR: quic: Support transport parameters draft TLS extension
3516 - MINOR: quic: Anti-amplification implementation
3517 - MINOR: quic: Wrong Initial packet connection initialization
3518 - MINOR: quic: Wrong ACK range building
3519 - MINOR: quic: Update some QUIC protocol errors
3520 - MINOR: quic: Send CONNECTION_CLOSE frame upon TLS alert
3521 - MINOR: quic: Wrong largest acked packet number parsing
3522 - MINOR: quic: Add minimalistic support for stream flow control frames
3523 - MINOR: quic: Wrong value for version negotiation packet 'Unused' field
3524 - MINOR: quic: Support draft-29 QUIC version
3525 - BUG/MINOR: quic: fix segfault on trace for version negotiation
3526 - BUG/MINOR: hq-interop: fix potential NULL dereference
3527 - BUILD: quic: fix potential NULL dereference on xprt_quic
3528 - DOC: lua: documentation about the httpclient API
3529 - BUG/MEDIUM: cache/cli: make "show cache" thread-safe
3530 - BUG/MEDIUM: shctx: leave the block allocator when enough blocks are found
3531 - BUG/MINOR: shctx: do not look for available blocks when the first one is enough
3532 - MINOR: shctx: add a few BUG_ON() for consistency checks
3533
Willy Tarreaud83f6e62021-11-14 16:04:57 +010035342021/11/14 : 2.5-dev14
3535 - DEV: coccinelle: Remove unused `expression e`
3536 - DEV: coccinelle: Add rule to use `istend()` where possible
3537 - CLEANUP: Apply ist.cocci
3538 - CLEANUP: Re-apply xalloc_size.cocci
3539 - CLEANUP: halog: make the default usage message fit in small screens
3540 - MINOR: h3/qpack: fix gcc11 warnings
3541 - MINOR: mux-quic: fix gcc11 warning
3542 - MINOR: h3: fix potential NULL dereference
3543 - MINOR: quic: Fix potential null pointer dereference
3544 - CLEANUP: halog: remove unused strl2ui()
3545 - OPTIM: halog: improve field parser speed for modern compilers
3546 - OPTIM: halog: skip fields 64 bits at a time when supported
3547 - DEV: coccinelle: Add rule to use `isttrim()` where possible
3548 - CLEANUP: Apply ist.cocci
3549 - DEV: coccinelle: Add rule to use `chunk_istcat()` instead of `chunk_memcat()`
3550 - DEV: coccinelle: Add rule to use `chunk_istcat()` instead of `chunk_strncat()`
3551 - CLEANUP: Apply ist.cocci
3552 - CLEANUP: chunk: Remove duplicated chunk_Xcat implementation
3553 - CLEANUP: chunk: remove misleading chunk_strncat() function
3554 - BUG/MINOR: cache: properly ignore unparsable max-age in quotes
3555 - Revert "DEV: coccinelle: Add rule to use `chunk_istcat()` instead of `chunk_strncat()`"
3556 - DOC: stats: fix location of the text representation
3557 - DOC: internals: document the IST API
3558 - BUG/MINOR: httpclient/lua: rcv freeze when no request payload
3559 - BUG/MEDIUM: httpclient: channel_add_input() must use htx->data
3560 - MINOR: promex: backend aggregated server check status
3561 - DOC: config: Fix typo in ssl_fc_unique_id description
3562 - BUG/MINOR: http-ana: Apply stop to the current section for http-response rules
3563 - Revert "BUG/MINOR: http-ana: Don't eval front after-response rules if stopped on back"
3564 - DOC: config: Be more explicit in "allow" actions description
3565 - DOC: lua: Be explicit with the Reply object limits
3566 - MINOR: mux-h1: Slightly Improve H1 traces
3567 - BUG/MEDIUM: conn-stream: Don't reset CS flags on close
3568 - CLEANUP: mworker: remove any relative PID reference
3569 - MEDIUM: mworker: reexec in waitpid mode after successful loading
3570 - MINOR: mworker: clarify starting/failure messages
3571 - MINOR: mworker: only increment the number of reload in wait mode
3572 - MINOR: mworker: implement a reload failure counter
3573 - MINOR: mworker: ReloadFailed shown depending on failedreload
3574 - MINOR: mworker: change the way we set PROC_O_LEAVING
3575 - BUG/MINOR: mworker: doesn't launch the program postparser
3576 - DOC: management: edit the "show proc" example to show the current output
3577 - BUG/MEDIUM: httpclient/cli: free of unallocated hc->req.uri
3578 - REGTESTS: httpclient/lua: add greater body values
3579 - BUG/MINOR: mux-h2: Fix H2_CF_DEM_SHORT_READ value
3580 - BUG/MINOR: pools: don't mark ourselves as harmless in DEBUG_UAF mode
3581 - BUG/MEDIUM: connection: make cs_shutr/cs_shutw//cs_close() idempotent
3582 - BUILD: makefile: simplify detection of libatomic
3583
Willy Tarreau08d32202021-11-06 09:25:57 +010035842021/11/06 : 2.5-dev13
3585 - SCRIPTS: git-show-backports: re-enable file-based filtering
3586 - MINOR: jwt: Make invalid static JWT algorithms an error in `jwt_verify` converter
3587 - MINOR: mux-h2: add trace on extended connect usage
3588 - BUG/MEDIUM: mux-h2: reject upgrade if no RFC8441 support
3589 - MINOR: stream/mux: implement websocket stream flag
3590 - MINOR: connection: implement function to update ALPN
3591 - MINOR: connection: add alternative mux_ops param for conn_install_mux_be
3592 - MEDIUM: server/backend: implement websocket protocol selection
3593 - MINOR: server: add ws keyword
3594 - BUG/MINOR: resolvers: fix sent messages were counted twice
3595 - BUG/MINOR: resolvers: throw log message if trash not large enough for query
3596 - MINOR: resolvers/dns: split dns and resolver counters in dns_counter struct
3597 - MEDIUM: resolvers: rename dns extra counters to resolvers extra counters
3598 - BUG/MINOR: jwt: Fix jwt_parse_alg incorrectly returning JWS_ALG_NONE
3599 - DOC: add QUIC instruction in INSTALL
3600 - CLEANUP: halog: Remove dead stores
3601 - DEV: coccinelle: Add ha_free.cocci
3602 - CLEANUP: Apply ha_free.cocci
3603 - DEV: coccinelle: Add rule to use `istnext()` where possible
3604 - CLEANUP: Apply ist.cocci
3605 - REGTESTS: Use `feature cmd` for 2.5+ tests (2)
3606 - DOC: internals: move some API definitions to an "api" subdirectory
3607 - MINOR: quic: Allocate listener RX buffers
3608 - CLEANUP: quic: Remove useless code
3609 - MINOR: quic: Enhance the listener RX buffering part
3610 - MINOR: quic: Remove a useless lock for CRYPTO frames
3611 - MINOR: quic: Use QUIC_LOCK QUIC specific lock label.
3612 - MINOR: backend: Get client dst address to set the server's one only if needful
3613 - MINOR: compression: Warn for 'compression offload' in defaults sections
3614 - MEDIUM: connection: rename fc_conn_err and bc_conn_err to fc_err and bc_err
3615 - DOC: configuration: move the default log formats to their own section
3616 - MINOR: ssl: make the ssl_fc_sni() sample-fetch function always available
3617 - MEDIUM: log: add the client's SNI to the default HTTPS log format
3618 - DOC: config: add an example of reasonably complete error-log-format
3619 - DOC: config: move error-log-format before custom log format
3620
Willy Tarreau35dc13f2021-11-02 18:05:41 +010036212021/11/02 : 2.5-dev12
3622 - MINOR: httpclient: support payload within a buffer
3623 - MINOR: httpclient/lua: support more HTTP methods
3624 - MINOR: httpclient/lua: return an error when it can't generate the request
3625 - CLEANUP: lua: Remove any ambiguities about lua txn execution context flags
3626 - BUG/MEDIUM: lua: fix invalid return types in hlua_http_msg_get_body
3627 - CLEANUP: connection: No longer export make_proxy_line_v1/v2 functions
3628 - CLEANUP: tools: Use const address for get_net_port() and get_host_port()
3629 - CLEANUP: lua: Use a const address to retrieve info about a connection
3630 - MINOR: connection: Add function to get src/dst without updating the connection
3631 - MINOR: session: Add src and dst addresses to the session
3632 - MINOR: stream-int: Add src and dst addresses to the stream-interface
3633 - MINOR: frontend: Rely on client src and dst addresses at stream level
3634 - MINOR: log: Rely on client addresses at the appropriate level to log messages
3635 - MINOR: session: Rely on client source address at session level to log error
3636 - MINOR: http-ana: Rely on addresses at stream level to set xff and xot headers
3637 - MINOR: http-fetch: Rely on addresses at stream level in HTTP sample fetches
3638 - MINOR: mux-fcgi: Rely on client addresses at stream level to set default params
3639 - MEDIUM: tcp-sample: Rely on addresses at the appropriate level in tcp samples
3640 - MEDIUM: connection: Rely on addresses at stream level to make proxy line
3641 - MEDIUM: backend: Rely on addresses at stream level to init server connection
3642 - MEDIUM: connection: Assign session addresses when PROXY line is received
3643 - MEDIUM: connection: Assign session addresses when NetScaler CIP proto is parsed
3644 - MEDIUM: tcp-act: Set addresses at the apprioriate level in set-(src/dst) actions
3645 - MINOR: tcp-act: Add set-src/set-src-port for "tcp-request content" rules
3646 - DOC: config: Fix alphabetical order of fc_* samples
3647 - MINOR: tcp-sample: Add samples to get original info about client connection
3648 - REGTESTS: Add script to test client src/dst manipulation at different levels
3649 - MINOR: stream: Use backend stream-interface dst address instead of target_addr
3650 - BUILD: log: Fix compilation without SSL support
3651 - DEBUG: protocol: yell loudly during registration of invalid sock_domain
3652 - MINOR: protocols: add a new protocol type selector
3653 - MINOR: protocols: make use of the protocol type to select the protocol
3654 - MINOR: protocols: replace protocol_by_family() with protocol_lookup()
3655 - MINOR: halog: Add -qry parameter allowing to preserve the query string in -uX
3656 - CLEANUP: jwt: Remove the use of a trash buffer in jwt_jwsverify_hmac()
3657 - CLEANUP: jwt: Remove the use of a trash buffer in jwt_jwsverify_rsa_ecdsa()
3658 - DEV: coccinelle: Add realloc_leak.cocci
3659 - CLEANUP: hlua: Remove obsolete branch in `hlua_alloc()`
3660 - BUILD: atomic: prefer __atomic_compare_exchange_n() for __ha_cas_dw()
3661 - BUILD: atomic: fix build on mac/arm64
3662 - MINOR: atomic: remove the memcpy() call and dependency on string.h
3663 - MINOR: httpclient: request streaming with a callback
3664 - MINOR: httpclient/lua: handle the streaming into the lua applet
3665 - REGTESTS: lua: test httpclient with body streaming
3666 - DOC: halog: Move the `-qry` parameter into the correct section in help text
3667 - MINOR: halog: Rename -qry to -query
3668 - CLEANUP: halog: Use consistent indentation in help()
3669 - BUG/MINOR: halog: Add missing newlines in die() messages
3670 - MINOR: halog: Add support for extracting captures using -hdr
3671 - DOC: Typo fixed "it" should be "is"
3672 - BUG/MINOR: mux-h1: Save shutdown mode if the shutdown is delayed
3673 - BUG/MEDIUM: mux-h1: Perform a connection shutdown when the h1c is released
3674 - BUG/MEDIUM: resolvers: Don't recursively perform requester unlink
3675 - BUG/MEDIUM: http-ana: Drain request data waiting the tarpit timeout expiration
3676 - BUG/MINOR: http: Authorization value can have multiple spaces after the scheme
3677 - BUG/MINOR: http: http_auth_bearer fetch does not work on custom header name
3678 - BUG/MINOR: httpclient/lua: misplaced luaL_buffinit()
3679 - BUILD/MINOR: cpuset freebsd build fix
3680 - BUG/MINOR: httpclient: use a placeholder value for Host header
3681 - BUG/MEDIUM: stream-int: Block reads if channel cannot receive more data
3682 - BUG/MEDIUM: resolvers: Track api calls with a counter to free resolutions
3683 - MINOR: stream: Improve dump of bogus streams
3684 - DOC/peers: some grammar fixes for peers 2.1 spec
3685 - MEDIUM: vars: make the var() sample fetch function really return type ANY
3686 - MINOR: vars: add "set-var" for "tcp-request connection" rules.
3687
Willy Tarreaub4d0cd02021-10-22 19:40:44 +020036882021/10/22 : 2.5-dev11
3689 - DEV: coccinelle: Add strcmp.cocci
3690 - CLEANUP: Apply strcmp.cocci
3691 - CI: Add `permissions` to GitHub Actions
3692 - CI: Clean up formatting in GitHub Action definitions
3693 - MINOR: add ::1 to predefined LOCALHOST acl
3694 - CLEANUP: assorted typo fixes in the code and comments
3695 - CLEANUP: Consistently `unsigned int` for bitfields
3696 - MEDIUM: resolvers: lower-case labels when converting from/to DNS names
3697 - MEDIUM: resolvers: replace bogus resolv_hostname_cmp() with memcmp()
3698 - MINOR: jwt: Empty the certificate tree during deinit
3699 - MINOR: jwt: jwt_verify returns negative values in case of error
3700 - MINOR: jwt: Do not rely on enum order anymore
3701 - BUG/MEDIUM: stream: Keep FLT_END analyzers if a stream detects a channel error
3702 - MINOR: httpclient/cli: access should be only done from expert mode
3703 - DOC: management: doc about the CLI httpclient
3704 - BUG/MEDIUM: tcpcheck: Properly catch early HTTP parsing errors
3705 - BUG/MAJOR: dns: tcp session can remain attached to a list after a free
3706 - BUG/MAJOR: dns: attempt to lock globaly for msg waiter list instead of use barrier
3707 - CLEANUP: dns: always detach the appctx from the dns session on release
3708 - DEBUG: dns: add a few more BUG_ON at sensitive places
3709 - BUG/MAJOR: resolvers: add other missing references during resolution removal
3710 - CLEANUP: resolvers: do not export resolv_purge_resolution_answer_records()
3711 - BUILD: resolvers: avoid a possible warning on null-deref
3712 - BUG/MEDIUM: resolvers: always check a valid item in query_list
3713 - CLEANUP: always initialize the answer_list
3714 - CLEANUP: resolvers: simplify resolv_link_resolution() regarding requesters
3715 - CLEANUP: resolvers: replace all LIST_DELETE with LIST_DEL_INIT
3716 - MEDIUM: resolvers: use a kill list to preserve the list consistency
3717 - MEDIUM: resolvers: remove the last occurrences of the "safe" argument
3718 - BUG/MEDIUM: checks: fix the starting thread for external checks
3719 - MEDIUM: resolvers: replace the answer_list with a (flat) tree
3720 - MEDIUM: resolvers: hash the records before inserting them into the tree
3721 - BUG/MAJOR: buf: fix varint API post- vs pre- increment
3722 - OPTIM: resolvers: move the eb32 node before the data in the answer_item
3723 - MINOR: list: add new macro LIST_INLIST_ATOMIC()
3724 - OPTIM: dns: use an atomic check for the list membership
3725 - BUG/MINOR: task: do not set TASK_F_USR1 for no reason
3726 - BUG/MINOR: mux-h2: do not prevent from sending a final GOAWAY frame
3727 - MINOR: connection: add a new CO_FL_WANT_DRAIN flag to force drain on close
3728 - MINOR: mux-h2: perform a full cycle shutdown+drain on close
3729 - CLEANUP: resolvers: get rid of single-iteration loop in resolv_get_ip_from_response()
3730 - MINOR: quic: Increase the size of handshake RX UDP datagrams
3731 - BUG/MEDIUM: lua: fix memory leaks with realloc() on non-glibc systems
3732 - MINOR: memprof: report the delta between alloc and free on realloc()
3733 - MINOR: memprof: add one pointer size to the size of allocations
3734 - BUILD: fix compilation on NetBSD
3735 - MINOR: backend: add traces for idle connections reuse
3736 - BUG/MINOR: backend: fix improper insert in avail tree for always reuse
3737 - MINOR: backend: improve perf with tcp proxies skipping idle conns
3738 - MINOR: connection: remove unneeded memset 0 for idle conns
3739
Willy Tarreauf2b1b4d2021-10-16 15:24:22 +020037402021/10/16 : 2.5-dev10
3741 - MINOR: initcall: Rename __GLOBL and __GLOBL1.
3742 - MINOR: rules: add a new function new_act_rule() to allocate act_rules
3743 - MINOR: rules: add a file name and line number to act_rules
3744 - MINOR: stream: report the current rule in "show sess all" when known
3745 - MINOR: stream: report the current filter in "show sess all" when known
3746 - CLEANUP: stream: Properly indent current_rule line in "show sess all"
3747 - BUG/MINOR: lua: Fix lua error handling in `hlua_config_prepend_path()`
3748 - CI: github: switch to OpenSSL 3.0.0
3749 - REGTESTS: ssl: Fix references to removed option in test description
3750 - MINOR: ssl: Add ssllib_name_startswith precondition
3751 - REGTESTS: ssl: Fix ssl_errors test for OpenSSL v3
3752 - REGTESTS: ssl: Reenable ssl_errors test for OpenSSL only
3753 - REGTESTS: ssl: Use mostly TLSv1.2 in ssl_errors test
3754 - MEDIUM: mux-quic: rationalize tx buffers between qcc/qcs
3755 - MEDIUM: h3: properly manage tx buffers for large data
3756 - MINOR: mux-quic: standardize h3 settings sending
3757 - CLEANUP: h3: remove dead code
3758 - MINOR: mux-quic: implement standard method to detect if qcc is dead
3759 - MEDIUM: mux-quic: defer stream shut if remaining tx data
3760 - MINOR: mux: remove last occurences of qcc ring buffer
3761 - MINOR: quic: handle CONNECTION_CLOSE frame
3762 - REGTESTS: ssl: re-enable set_ssl_cert_bundle.vtc
3763 - MINOR: ssl: add ssl_fc_is_resumed to "option httpslog"
3764 - MINOR: http: Add http_auth_bearer sample fetch
3765 - MINOR: jwt: Parse JWT alg field
3766 - MINOR: jwt: JWT tokenizing helper function
3767 - MINOR: jwt: Insert public certificates into dedicated JWT tree
3768 - MINOR: jwt: jwt_header_query and jwt_payload_query converters
3769 - MEDIUM: jwt: Add jwt_verify converter to verify JWT integrity
3770 - REGTESTS: jwt: Add tests for the jwt_verify converter
3771 - BUILD: jwt: fix declaration of EVP_KEY in jwt-h.h
3772 - MINOR: proto_tcp: use chunk_appendf() to ouput socket setup errors
3773 - MINOR: proto_tcp: also report the attempted MSS values in error message
3774 - MINOR: inet: report the faulty interface name in "bind" errors
3775 - MINOR: protocol: report the file and line number for binding/listening errors
3776 - MINOR: protocol: uniformize protocol errors
3777 - MINOR: resolvers: fix the resolv_str_to_dn_label() API about trailing zero
3778 - BUG/MEDIUM: resolver: make sure to always use the correct hostname length
3779 - BUG/MINOR: resolvers: do not reject host names of length 255 in SRV records
3780 - MINOR: resolvers: fix the resolv_dn_label_to_str() API about trailing zero
3781 - MEDIUM: listeners: split the thread mask between receiver and bind_conf
3782 - MINOR: listeners: add clone_listener() to duplicate listeners at boot time
3783 - MEDIUM: listener: add the "shards" bind keyword
3784 - BUG/MEDIUM: resolvers: use correct storage for the target address
3785 - MINOR: resolvers: merge address and target into a union "data"
3786 - BUG/MEDIUM: resolvers: fix truncated TLD consecutive to the API fix
3787 - BUG/MEDIUM: jwt: fix base64 decoding error detection
3788 - BUG/MINOR: jwt: use CRYPTO_memcmp() to compare HMACs
3789 - DOC: jwt: fix a typo in the jwt_verify() keyword description
3790 - BUG/MEDIUM: sample/jwt: fix another instance of base64 error detection
3791 - BUG/MINOR: http-ana: Don't eval front after-response rules if stopped on back
3792 - BUG/MINOR: sample: Fix 'fix_tag_value' sample when waiting for more data
3793 - DOC: config: Move 'tcp-response content' at the right place
3794 - BUG/MINOR: proxy: Use .disabled field as a bitfield as documented
3795 - MINOR: proxy: Introduce proxy flags to replace disabled bitfield
3796 - MINOR: sample/arg: Be able to resolve args found in defaults sections
3797 - MEDIUM: proxy: Warn about ambiguous use of named defaults sections
3798 - MINOR: proxy: Be able to reference the defaults section used by a proxy
3799 - MINOR: proxy: Add PR_FL_READY flag on fully configured and usable proxies
3800 - MINOR: config: Finish configuration for referenced default proxies
3801 - MINOR: config: No longer remove previous anonymous defaults section
3802 - MINOR: tcpcheck: Support 2-steps args resolution in defaults sections
3803 - MEDIUM: rules/acl: Parse TCP/HTTP rules and acls defined in defaults sections
3804 - MEDIUM: tcp-rules: Eval TCP rules defined in defaults sections
3805 - MEDIUM: http-ana: Eval HTTP rules defined in defaults sections
3806 - BUG/MEDIUM: sample: Cumulate frontend and backend sample validity flags
3807 - REGTESTS: Add scripts to test support of TCP/HTTP rules in defaults sections
3808 - DOC: config: Add documentation about TCP/HTTP rules in defaults section
3809 - DOC: config: Rework and uniformize how TCP/HTTP rules are documented
3810 - BUG/MINOR: proxy: Release ACLs and TCP/HTTP rules of default proxies
3811 - BUG/MEDIUM: cpuset: fix cpuset size for FreeBSD
3812 - BUG/MINOR: sample: fix backend direction flags consecutive to last fix
3813 - BUG/MINOR: listener: fix incorrect return on out-of-memory
3814 - BUG/MINOR: listener: add an error check for unallocatable trash
3815 - CLEANUP: listeners: remove unreachable code in clone_listener()
3816
Willy Tarreau4c67bd62021-10-08 18:22:24 +020038172021/10/08 : 2.5-dev9
3818 - head-truc
3819 - REGTESTS: lua: test the httpclient:get() feature
3820 - Revert "head-truc"
3821 - BUG/MEDIUM: httpclient: replace ist0 by istptr
3822 - MINOR: config: use a standard parser for the "nbthread" keyword
3823 - CLEANUP: init: remove useless test against MAX_THREADS in affinity loop
3824 - MEDIUM: init: de-uglify the per-thread affinity setting
3825 - MINOR: init: extract the setup and end of threads to their own functions
3826 - MINOR: log: Try to get the status code when MUX_EXIT_STATUS is retrieved
3827 - MINOR: mux-h1: Set error code if possible when MUX_EXIT_STATUS is returned
3828 - MINOR: mux-h1: Be able to set custom status code on parsing error
3829 - MEDIUM: mux-h1: Reject HTTP/1.0 GET/HEAD/DELETE requests with a payload
3830 - MEDIUM: h1: Force close mode for invalid uses of T-E header
3831 - BUG/MINOR: mux-h1/mux-fcgi: Sanitize TE header to only send "trailers"
3832 - MINOR: http: Add 422-Unprocessable-Content error message
3833 - MINOR: h1: Change T-E header parsing to fail if chunked encoding is found twice
3834 - BUG/MEDIUM: mux-h1/mux-fcgi: Reject messages with unknown transfer encoding
3835 - REGTESTS: Add script to validate T-E header parsing
3836 - REORG: pools: move default settings to defaults.h
3837 - DOC: peers: fix doc "enable" statement on "peers" sections
3838 - MINOR: Makefile: add MEMORY_POOLS to the list of DEBUG_xxx options
3839 - MINOR: ssl: Set connection error code in case of SSL read or write fatal failure
3840 - MINOR: ssl: Rename ssl_bc_hsk_err to ssl_bc_err
3841 - MINOR: ssl: Store the last SSL error code in case of read or write failure
3842 - REGTESTS: ssl: enable show_ssl_ocspresponse.vtc again
3843 - REGTESTS: ssl: enable ssl_crt-list_filters.vtc again
3844 - BUG/MEDIUM: lua: fix wakeup condition from sleep()
3845 - BUG/MAJOR: lua: use task_wakeup() to properly run a task once
3846 - MINOR: arg: Be able to forbid unresolved args when building an argument list
3847 - BUG/MINOR: tcpcheck: Don't use arg list for default proxies during parsing
3848 - BUG/MINOR: tcp-rules: Stop content rules eval on read error and end-of-input
3849 - MINOR: tasks: catch TICK_ETERNITY with BUG_ON() in __task_queue()
3850 - REGTESTS: ssl: show_ssl_ocspresponse w/ freebsd won't use base64
3851 - REGTESTS: ssl: wrong feature cmd in show_ssl_ocspresponse.vtc
3852 - CLEANUP: tasks: remove the long-unused work_lists
3853 - MINOR: task: provide 3 task_new_* wrappers to simplify the API
3854 - MINOR: time: uninline report_idle() and move it to task.c
3855 - REORG: sched: move idle time calculation from time.h to task.h
3856 - REORG: sched: move the stolen CPU time detection to sched_entering_poll()
3857 - BUG/MEDIUM: filters: Fix a typo when a filter is attached blocking the release
3858 - BUG/MEDIUM: http-ana: Clear request analyzers when applying redirect rule
3859 - MINOR: httpclient: destroy() must free the headers and the ists
3860 - MINOR: httpclient: set HTTPCLIENT_F_ENDED only in release
3861 - MINOR: httpclient: stop_and_destroy() ask the applet to autokill
3862 - MINOR: httpclient: test if started during stop_and_destroy()
3863 - MINOR: httpclient/lua: implement garbage collection
3864 - BUG/MEDIUM: httpclient/lua: crash because of b_xfer and get_trash_chunk()
3865 - MINOR: httpclient: destroy checks if a client was started but not stopped
3866 - BUG/MINOR: httpclient/lua: does not process headers when failed
3867 - MINOR: httpclient/lua: supports headers via named arguments
3868 - CLEANUP: server: always include the storage for SSL settings
3869 - CLEANUP: sample: rename sample_conv_var2smp() to *_sint
3870 - CLEANUP: sample: uninline sample_conv_var2smp_str()
3871 - MINOR: sample: provide a generic var-to-sample conversion function
3872 - BUG/MEDIUM: sample: properly verify that variables cast to sample
3873 - BUILD: action: add the relevant structures for function arguments
3874 - BUILD: extcheck: needs to include stream-t.h
3875 - BUILD: hlua: needs to include stream-t.h
3876 - BUILD: stats: define several missing structures in stats.h
3877 - BUILD: resolvers: define missing types in resolvers.h
3878 - BUILD: httpclient: include missing ssl_sock-t
3879 - BUILD: sample: include openssl-compat
3880 - BUILD: http_ana: need to include proxy-t to get redirect_rule
3881 - BUILD: http_rules: requires http_ana-t.h for REDIRECT_*
3882 - BUILD: vars: need to include xxhash
3883 - BUILD: peers: need to include eb{32/mb/pt}tree.h
3884 - BUILD: ssl_ckch: include ebpttree.h in ssl_ckch.c
3885 - BUILD: compiler: add the container_of() and container_of_safe() macros
3886 - BUILD: idleconns: include missing ebmbtree.h at several places
3887 - BUILD: connection: connection.h needs list.h and server.h
3888 - BUILD: tree-wide: add missing http_ana.h from many places
3889 - BUILD: cfgparse-ssl: add missing errors.h
3890 - BUILD: tcp_sample: include missing errors.h and session-t.h
3891 - BUILD: mworker: mworker-prog needs time.h for the 'now' variable
3892 - BUILD: tree-wide: add several missing activity.h
3893 - BUILD: compat: fix -Wundef on SO_REUSEADDR
3894 - CLEANUP: pools: pools-t.h doesn't need to include thread-t.h
3895 - REORG: pools: uninline the UAF allocator and force-inline the rest
3896 - REORG: thread: uninline the lock-debugging code
3897 - MINOR: thread/debug: replace nsec_now() with now_mono_time()
3898 - CLEANUP: remove some unneeded includes from applet-t.h
3899 - REORG: listener: move bind_conf_alloc() and listener_state_str() to listener.c
3900 - CLEANUP: listeners: do not include openssl-compat
3901 - CLEANUP: servers: do not include openssl-compat
3902 - REORG: ssl: move ssl_sock_is_ssl() to connection.h and rename it
3903 - CLEANUP: mux_fcgi: remove dependency on ssl_sock
3904 - CLEANUP: ssl/server: move ssl_sock_set_srv() to srv_set_ssl() in server.c
3905 - REORG: ssl-sock: move the sslconns/totalsslconns counters to global
3906 - REORG: sample: move the crypto samples to ssl_sample.c
3907 - REORG: sched: moved samp_time and idle_time to task.c as well
3908 - REORG: time/ticks: move now_ms and global_now_ms definitions to ticks.h
3909 - CLEANUP: tree-wide: remove unneeded include time.h in ~20 files
3910 - REORG: activity: uninline activity_count_runtime()
3911 - REORG: acitvity: uninline sched_activity_entry()
3912 - CLEANUP: stream: remove many unneeded includes from stream-t.h
3913 - CLEANUP: stick-table: no need to include socket nor in.h
3914 - MINOR: connection: use uint64_t for the hashes
3915 - REORG: connection: move the hash-related stuff to connection.c
3916 - REORG: connection: uninline conn_notify_mux() and conn_delete_from_tree()
3917 - REORG: server: uninline the idle conns management functions
3918 - REORG: ebtree: split structures into their own file ebtree-t.h
3919 - CLEANUP: tree-wide: only include ebtree-t from type files
3920 - REORG: connection: move the largest inlines from connection.h to connection.c
3921 - CLEANUP: connection: do not include http_ana!
3922 - CLEANUP: connection: remove unneeded tcpcheck-t.h and use only session-t.h
3923 - REORG: connection: uninline the rest of the alloc/free stuff
3924 - REORG: task: uninline the loop time measurement code
3925 - CLEANUP: time: move a few configurable defines to defaults.h
3926 - CLEANUP: fd: do not include time.h
3927 - REORG: fd: uninline compute_poll_timeout()
3928 - CLENAUP: wdt: use ha_tkill() instead of accessing pthread directly
3929 - REORG: thread: move the thread init/affinity/stop to thread.c
3930 - REORG: thread: move ha_get_pthread_id() to thread.c
3931 - MINOR: thread: use a dedicated static pthread_t array in thread.c
3932 - CLEANUP: thread: uninline ha_tkill/ha_tkillall/ha_cpu_relax()
3933 - DOC: configuration: add clarification on escaping in keyword arguments
3934 - BUG/MINOR: task: fix missing include with DEBUG_TASK
3935 - MINOR: pools: report the amount used by thread caches in "show pools"
3936 - MINOR: quic: Distinguish packet and SSL read enc. level in traces
3937 - MINOR: quic: Add a function to dump SSL stack errors
3938 - MINOR: quic: BUG_ON() SSL errors.
3939 - MINOR: quic: Fix SSL error issues (do not use ssl_bio_and_sess_init())
3940 - BUG/MEDIUM: mux-quic: reinsert all streams in by_id tree
3941 - BUG/MAJOR: xprt-quic: do not queue qc timer if not set
3942 - MINOR: mux-quic: release connection if no more bidir streams
3943 - BUG/MAJOR: quic: remove qc from receiver cids tree on free
3944 - BUG/MEDIUM: mux_h2: Handle others remaining read0 cases on partial frames
3945 - MINOR: qpack: do not encode invalid http status code
3946 - MINOR: qpack: support non-indexed http status code encoding
3947 - MINOR: qpack: fix memory leak on huffman decoding
3948 - CLEANUP: mux-quic: remove unused code
3949 - BUG/MINOR: quic: fix includes for compilation
3950 - BUILD: connection: avoid a build warning on FreeBSD with SO_USER_COOKIE
3951 - BUILD: init: avoid a build warning on FreeBSD with USE_PROCCTL
3952 - REORG: time: move time-keeping code and variables to clock.c
3953 - REORG: clock: move the updates of cpu/mono time to clock.c
3954 - MINOR: activity: get the run_time from the clock updates
3955 - CLEANUP: clock: stop exporting before_poll and after_poll
3956 - REORG: clock: move the clock_id initialization to clock.c
3957 - REORG: clock/wdt: move wdt timer initialization to clock.c
3958 - MINOR: clock: move the clock_ids to clock.c
3959 - MINOR: wdt: move wd_timer to wdt.c
3960 - CLEANUP: wdt: do not remap SI_TKILL to SI_LWP, test the values directly
3961 - REORG: thread/sched: move the task_per_thread stuff to thread_ctx
3962 - REORG: thread/clock: move the clock parts of thread_info to thread_ctx
3963 - REORG: thread/sched: move the thread_info flags to the thread_ctx
3964 - REORG: thread/sched: move the last dynamic thread_info to thread_ctx
3965 - MINOR: thread: make "ti" a const pointer and clean up thread_info a bit
3966 - MINOR: threads: introduce a minimalistic notion of thread-group
3967 - MINOR: global: add a new "thread-groups" directive
3968 - MINOR: global: add a new "thread-group" directive
3969 - MINOR: threads: make tg point to the current thread's group
3970 - MEDIUM: threads: automatically assign threads to groups
3971 - MINOR: threads: set the group ID and its bit in the thread group
3972 - MINOR: threads: set the tid, ltid and their bit in thread_cfg
3973 - MEDIUM: threads: replace ha_set_tid() with ha_set_thread()
3974 - MINOR: threads: add the current group ID in thread-local "tgid" variable
3975 - MINOR: debug: report the group and thread ID in the thread dumps
3976 - MEDIUM: listeners: support the definition of thread groups on bind lines
3977 - MINOR: threads: add a new function to resolve config groups and masks
3978 - MEDIUM: config: resolve relative threads on bind lines to absolute ones
3979 - MEDIUM: stick-table: never learn the "conn_cur" value from peers
3980
Willy Tarreau538f3e02021-09-24 15:52:17 +020039812021/09/24 : 2.5-dev8
3982 - BUILD: compiler: fixed a missing test on defined(__GNUC__)
3983 - BUILD: halog: fix a -Wundef warning on non-glibc systems
3984 - BUILD: threads: fix -Wundef for _POSIX_PRIORITY_SCHEDULING on libmusl
3985 - BUG/MINOR: compat: make sure __WORDSIZE is always defined
3986 - BUILD: sample: fix format warning on 32-bit archs in sample_conv_be2dec_check()
3987 - CLEANUP: pools: factor all malloc_trim() calls into trim_all_pools()
3988 - MINOR: pools: automatically disable malloc_trim() with external allocators
3989 - MINOR: pools: report it when malloc_trim() is enabled
3990 - DOC: Add .mailmap
3991 - CLEANUP: tree-wide: fix prototypes for functions taking no arguments.
3992 - CLEANUP: Remove prototype for non-existent thread_get_default_count()
3993 - CLEANUP: acl: Remove unused variable when releasing an acl expression
3994 - BUG/MAJOR: mux-h1: Don't eval input data if an error was reported
3995 - DOC: update Tim's address in .mailmap
3996 - MINOR: pools: use mallinfo2() when available instead of mallinfo()
3997 - BUG/MINOR: tcpcheck: Improve LDAP response parsing to fix LDAP check
3998 - DOC: management: certificate files must be sanitized before injection
3999 - BUG/MINOR: connection: prevent null deref on mux cleanup task allocation
4000 - BUILD: ist: prevent gcc11 maybe-uninitialized warning on istalloc
4001 - BUG/MINOR: cli/payload: do not search for args inside payload
4002 - BUILD: sockpair: do not set unused flag
4003 - BUILD: proto_uxst: do not set unused flag
4004 - BUILD: fd: remove unused variable totlen in fd_write_frag_line()
4005 - MINOR: applet: remove the thread mask from appctx_new()
4006 - REORG: threads: move ha_get_pthread_id() to tinfo.h
4007 - CLEANUP: Apply ist.cocci
4008 - DEV: coccinelle: Add ist.cocci
4009 - CLEANUP: Apply bug_on.cocci
4010 - DEV: coccinelle: Add xalloc_size.cocci
4011 - DEV: coccinelle: Add bug_on.cocci
4012 - CLEANUP: Apply xalloc_size.cocci
4013 - DEV: coccinelle: Add xalloc_cast.cocci
4014 - BUG/MINOR: flt-trace: fix an infinite loop when random-parsing is set
4015 - MINOR: httpclient: add the EOH when no headers where provided
4016 - CLEANUP: Include check.h in flt_spoe.c
4017 - CLEANUP: Remove unreachable `break` from parse_time_err()
4018 - BUG/MINOR: server: allow 'enable health' only if check configured
4019 - BUG/MINOR: server: alloc dynamic srv ssl ctx if proxy uses ssl chk rule
4020 - MINOR: server: enable more keywords for ssl checks for dynamic servers
4021 - MINOR: server: enable more check related keywords for dynamic servers
4022 - REORG: server: move slowstart init outside of checks
4023 - MINOR: server: enable slowstart for dynamic server
4024 - MEDIUM: listener: deprecate "process" in favor of "thread" on bind lines
4025 - BUG/MEDIUM: leastconn: fix rare possibility of divide by zero
4026 - BUG/MINOR: quic: Possible NULL pointer dereferencing when dumping streams.
4027 - MINOR: quic: Move transport parmaters to anynomous struct.
4028 - MINOR: mux_quic: Add QUIC mux layer.
4029 - MINOR: connection: Add callbacks definitions for QUIC.
4030 - MINOR: quic: Attach QUIC mux connection objet to QUIC connection.
4031 - MINOR: quic: Add a new definition to store STREAM frames.
4032 - MINOR: h3: Add HTTP/3 definitions.
4033 - MINOR: qpack: Add QPACK compression.
4034 - MINOR: quic_sock: Finalize the QUIC connections.
4035 - MINOR: quic: Disable the action of ->rcv_buf() xprt callback
4036 - MINOR: quic: Add callbacks for (un)scribing to QUIC xprt.
4037 - MINOR: quic: Variable-length integer encoding/decoding into/from buffer struct.
4038 - BUG/MINOR: quic: Wrong ->accept() error handling
4039 - MINOR: quic: Add a wrapper function to update transport parameters.
4040 - MINOR: quic: Update the streams transport parameters.
4041 - MINOR: quic: Avoid header collisions
4042 - MINOR: quic: Replace max_packet_size by max_udp_payload size.
4043 - MINOR: quic: Enable some quic, h3 and qpack modules compilation.
4044 - MINOR: quic: Move an SSL func call from QUIC I/O handler to the xprt init.
4045 - MINOR: quic: Initialize the session before starting the xprt.
4046 - BUG/MINOR: quic: Do not check the acception of a new conn from I/O handler.
4047 - MINOR: quic: QUIC conn initialization from I/O handler
4048 - MINOR: quic: Remove header protection for conn with context
4049 - MINOR: quic: Derive the initial secrets asap
4050 - MINOR: quic: Remove header protection also for Initial packets
4051 - BUG/MINOR: quic: Wrong memory free in quic_update_ack_ranges_list()
4052 - MINOR: quic: quic_update_ack_ranges_list() code factorization
4053 - MINOR: quic: Useless test in quic_update_ack_ranges_list()
4054 - MINOR: quic: Remove a useless variable in quic_update_ack_ranges_list()
4055 - BUG/MINOR: quic: Missing cases treatement when updating ACK ranges
4056 - CLEAUNUP: quic: Usage of a useless variable in qc_treat_rx_pkts()
4057 - BUG/MINOR: quic: Wrong RX packet reference counter usage
4058 - MINOR: quic: Do not stop the packet parsing too early in qc_treat_rx_packets()
4059 - MINOR: quic: Add a lock for RX packets
4060 - MINOR: quic: Move the connection state
4061 - MINOR: quic: Replace quic_conn_ctx struct by ssl_sock_ctx struct
4062 - MINOR: quic: Replace the RX list of packet by a thread safety one.
4063 - MINOR: quic: Replace the RX unprotected packet list by a thread safety one.
4064 - MINOR: quic: Add useful traces for I/O dgram handler
4065 - MINOR: quic: Do not wakeup the xprt task on ACK receipt
4066 - MINOR: quic: Connection allocations rework
4067 - MINOR: quic: Move conn_prepare() to ->accept_conn() callback
4068 - MINOR: quic: Make qc_lstnr_pkt_rcv() be thread safe.
4069 - MINOR: quic: Add a ring buffer implementation for QUIC
4070 - MINOR: quic: Prefer x25519 as ECDH preferred parametes.
4071 - MINOR: quic: Add the QUIC v1 initial salt.
4072 - BUG/MINOR: quic: Too much reduced computed space to build handshake packets
4073 - MINOR: net_helper: add functions for pointers
4074 - MINOR: quic: Add ring buffer definition (struct qring) for QUIC
4075 - MINOR: proto_quic: Allocate TX ring buffers for listeners
4076 - MINOR: quic: Initialize pointers to TX ring buffer list
4077 - MINOR: quic: Make use of TX ring buffers to send QUIC packets
4078 - MINOR: quic_tls: Make use of the QUIC V1 salt.
4079 - MINOR: quic: Remove old TX buffer implementation
4080 - MINOR: Add function for TX packets reference counting
4081 - MINOR: quic: Add TX packets at the very last time to their tree.
4082 - MINOR: quic: Unitialized mux context upon Client Hello message receipt.
4083 - MINOR: quic: Missing encryption level rx.crypto member initialization and lock.
4084 - MINOR: quic: Rename ->rx.rwlock of quic_enc_level struct to ->rx.pkts_rwlock
4085 - MINOR: quic: Make qc_treat_rx_pkts() be thread safe.
4086 - MINOR: quic: Make ->tx.frms quic_pktns struct member be thread safe
4087 - MINOR: quic: Replace quic_tx_frm struct by quic_frame struct
4088 - MINOR: quic: Add a mask for TX frame builders and their authorized packet types
4089 - MINOR: quic: Add a useful function to compute any frame length.
4090 - MINOR: quic: Add the QUIC connection state to traces
4091 - MINOR: quic: Store post handshake frame in ->pktns.tx.frms MT_LIST
4092 - MINOR: quic: Add the packet type to quic_tx_packet struct
4093 - MINOR: quic: Modify qc_do_build_hdshk_pkt() to accept any packet type
4094 - MINOR: quic: Atomically handle packet number space ->largest_acked_pn variable
4095 - MINOR: quic: Modify qc_build_cfrms() to support any frame
4096 - MINOR: quic: quic_conn_io_cb() task rework
4097 - MINOR: quic: Make qc_build_hdshk_pkt() atomically consume a packet number
4098 - MINOR: quic: qc_do_build_hdshk_pkt() does not need to pass a copy of CRYPTO frame
4099 - MINOR: quic: Remove Application level related functions
4100 - MINOR: quic: Rename functions which do not build only Handshake packets
4101 - MINOR: quic: Make circular buffer internal buffers be variable-sized.
4102 - MINOR: quic: Add a pool for TX ring buffer internal buffer
4103 - MINOR: quic: Make use of the last cbuf API when initializing TX ring buffers
4104 - MINOR: quic: Missing acks encoded size updates.
4105 - MINOR: quic: Evaluate the packet lengths in advance
4106 - MINOR: quic: Update the TLS extension for QUIC transport parameters
4107 - MINOR: quic: Fix handshake state debug strings
4108 - MINOR: quic: Atomically get/set the connection state
4109 - MINOR: quic: Missing QUIC encryption level for qc_build_pkt()
4110 - MINOR: quic: Coalesce Application level packets with Handshake packets.
4111 - MINOR: quic: Wrong flags handling for acks
4112 - MINOR: quic: Missing case when discarding HANDSHAKE secrets
4113 - MINOR: quic: Post handshake packet building improvements
4114 - MINOR: quic: Prepare Application level packet asap.
4115 - MINOR: h3: Send h3 settings asap
4116 - MINOR: quic: Wrong STREAM frame length computing
4117 - MINOR: quic: Wrong short packet minimum length
4118 - MINOR: quic: Prepare STREAM frames to fill QUIC packets
4119 - MINOR: h3: change default settings
4120 - MINOR: quic-enc: fix varint encoding
4121 - MINOR: qpack: fix wrong comment
4122 - MINOR: qpack: generate headers list on decoder
4123 - MINOR: h3: parse headers to htx
4124 - MINOR: h3: allocate stream on headers
4125 - MEDIUM: mux-quic: implement ring buffer on stream tx
4126 - MINOR: mux-quic: send SETTINGS on uni stream
4127 - MINOR: h3: define snd_buf callback and divert mux ops
4128 - MINOR: mux-quic: define FIN stream flag
4129 - MINOR: qpack: create qpack-enc module
4130 - MINOR: qpack: encode headers functions
4131 - MINOR: h3: encode htx headers to QPACK
4132 - MINOR: h3: send htx data
4133 - MINOR: h3/mux: detect fin on last h3 frame of the stream
4134 - MINOR: quic: Shorten some handshakes
4135 - MINOR: quic: Make QUIC-TLS support at least two initial salts
4136 - MINOR: quic: Attach the QUIC connection to a thread.
4137 - MINOR: quic: Missing active_connection_id_limit default value
4138 - MINOR: quic_sock: Do not flag QUIC connections as being set
4139 - MINOR: buf: Add b_force_xfer() function
4140 - MINOR: quic: Make use of buffer structs to handle STREAM frames
4141 - MINOR: mux_quic: move qc_process() code to qc_send()
4142 - MINOR: quic: Add a typedef for unsigned long long
4143 - MINOR: quic: Confusion between TX/RX for the frame builders
4144 - MINOR: quic: Wrong packet flags settings during frame building
4145 - MINOR: quic: Constantness fixes for frame builders/parsers.
4146 - MINOR: quic_tls: Client/serveur state reordering
4147 - MINOR: quic: Wrong packet loss detection due to wrong pktns order
4148 - MINOR: quic: Wrong packet number space selection in quic_loss_pktns()
4149 - MINOR: quic: Initial packet number spaced not discarded
4150 - MINOR: quic: Add useful trace about pktns discarding
4151 - MINOR: mux_quic: Export the mux related flags
4152 - MINOR: quic: Implement quic_conn_subscribe()
4153 - MINOR: quic: Wake up the mux upon ACK receipt
4154 - MINOR: quic: Stream FIN bit fix in qcs_push_frame()
4155 - MINOR: quic: Implement qc_process_mux()
4156 - MINOR: quic: Wake up the xprt from mux
4157 - CLEANUP: quic: Remove useless inline functions
4158 - MINOR: quic: RX packets memory leak
4159 - MINOR: quic: Possible endless loop in qc_treat_rx_pkts()
4160 - MINOR: quic: Crash upon too big packets receipt
4161 - MINOR: quic: define close handler
4162 - MEDIUM: quic: implement mux release/conn free
4163 - MINOR: quic: fix qcc subs initialization
4164 - BUG/MINOR: h1-htx: Fix a typo when request parser is reset
4165 - BUG/MEDIUM: mux-h1: Adjust conditions to ask more space in the channel buffer
4166 - BUG/MEDIUM: stream-int: Notify stream that the mux wants more room to xfer data
4167 - BUG/MEDIUM: stream: Stop waiting for more data if SI is blocked on RXBLK_ROOM
4168 - MINOR: stream-int: Set CO_RFL transient/persistent flags apart in si_cs_rcv()
4169 - MINOR: htx: Add an HTX flag to know when a message is fragmented
4170 - MINOR: htx: Add a function to know if the free space wraps
4171 - BUG/MEDIUM: stream-int: Defrag HTX message in si_cs_recv() if necessary
4172 - MINOR: stream-int: Notify mux when the buffer is not stuck when calling rcv_buf
4173 - BUG/MINOR: http-ana: increment internal_errors counter on response error
4174 - MINOR: stats: Enable dark mode on stat web page
4175 - CLEANUP: stats: Fix some alignment mistakes
4176 - MINOR: httpclient: httpclient_data() returns the available data
4177 - MINOR: httpclient: httpclient_ended() returns 1 if the client ended
4178 - MINOR: httpclient/lua: httpclient:get() API in lua
4179 - MINOR: httpclient/lua: implement the headers in the response object
4180 - BUG/MINOR: httpclient/lua: return an error on argument check
4181 - CLEANUP: slz: Mark `reset_refs` as static
4182
Willy Tarreau4b3a9fe2021-09-12 11:36:38 +020041832021/09/12 : 2.5-dev7
4184 - BUG/MINOR: config: reject configs using HTTP with bufsize >= 256 MB
4185 - CLEANUP: htx: remove comments about "must be < 256 MB"
4186 - BUG/MAJOR: htx: fix missing header name length check in htx_add_header/trailer
4187 - Revert "BUG/MINOR: stream-int: Don't block reads in si_update_rx() if chn may receive"
4188 - MINOR: proxy: add a global "grace" directive to postpone soft-stop
4189 - MINOR: vars: rename vars_init() to vars_init_head()
4190 - CLEANUP: vars: rename sample_clear_stream() to var_unset()
4191 - REORG: vars: remerge sample_store{,_stream}() into var_set()
4192 - MEDIUM: vars: make the ifexist variant of set-var only apply to the proc scope
4193 - MINOR: vars: add a VF_CREATEONLY flag for creation
4194 - MINOR: vars: support storing empty sample data with a variable
4195 - MINOR: vars: store flags into variables and add VF_PERMANENT
4196 - MEDIUM: vars: make var_clear() only reset VF_PERMANENT variables
4197 - MEDIUM: vars: pre-create parsed SCOPE_PROC variables as permanent ones
4198 - MINOR: vars: preset a random seed to hash variables names
4199 - MEDIUM: vars: replace the global name index with a hash
4200 - CLEANUP: vars: remove the now unused var_names array
4201 - MINOR: vars: centralize the lock/unlock into static inlines
4202 - OPTIM: vars: only takes the variables lock on shared entries
4203 - OPTIM: vars: remove internal bookkeeping for vars_global_size
4204 - OPTIM: vars: do not keep variables usage stats if no limit is set
4205 - BUILD: fix dragonfly build again on __read_mostly
4206 - CI: Github Actions: temporarily disable Opentracing
4207 - BUG/MEDIUM: mux-h1: Remove "Upgrade:" header for requests with payload
4208 - MINOR: htx: Skip headers with no value when adding a header list to a message
4209 - CLEANUP: mux-h1: Remove condition rejecting upgrade requests with payload
4210 - BUG/MEDIUM: stream-int: Don't block SI on a channel policy if EOI is reached
4211 - BUG/MEDIUM: http-ana: Reset channels analysers when returning an error
4212 - BUG/MINOR: filters: Set right FLT_END analyser depending on channel
4213 - CLEANUP: Add haproxy/xxhash.h to avoid modifying import/xxhash.h
4214 - CLEANUP: ebmbtree: Replace always-taken elseif by else
4215 - CLEANUP: Move XXH3 macro from haproxy/compat.h to haproxy/xxhash.h
4216 - BUILD: opentracing: exclude the use of haproxy variables for the OpenTracing context
4217 - BUG/MINOR: opentracing: enable the use of http headers without a set value
4218 - CLEANUP: opentracing: use the haproxy function to generate uuid
4219 - MINOR: opentracing: change the scope of the variable 'ot.uuid' from 'sess' to 'txn'
4220 - CI: Github Actions: re-enable Opentracing
4221 - CLEANUP: opentracing: simplify the condition on the empty header
4222 - BUG/MEDIUM lua: Add missing call to RESET_SAFE_LJMP in hlua_filter_new()
4223
Willy Tarreauf653e832021-09-03 15:19:56 +020042242021/09/03 : 2.5-dev6
4225 - BUG/MINOR threads: Use get_(local|gm)time instead of (local|gm)time
4226 - BUG/MINOR: tools: Fix loop condition in dump_text()
4227 - BUILD: ssl: next round of build warnings on LIBRESSL_VERSION_NUMBER
4228 - BUILD: ssl: fix two remaining occurrences of #if USE_OPENSSL
4229 - BUILD: tools: properly guard __GLIBC__ with defined()
4230 - BUILD: globally enable -Wundef
4231 - MINOR: log: Remove log-error-via-logformat option
4232 - MINOR: log: Add new "error-log-format" option
4233 - BUG/MAJOR: queue: better protect a pendconn being picked from the proxy
4234 - CLEANUP: Add missing include guard to signal.h
4235 - MINOR: ssl: Add new ssl_bc_hsk_err sample fetch
4236 - MINOR: connection: Add a connection error code sample fetch for backend side
4237 - REGTESTS: ssl: Add tests for bc_conn_err and ssl_bc_hsk_err sample fetches
4238 - MINOR: http-rules: add a new "ignore-empty" option to redirects.
4239 - CI: Github Actions: temporarily disable BoringSSL builds
4240 - BUG/MINOR: vars: fix set-var/unset-var exclusivity in the keyword parser
4241 - BUG/MINOR: vars: improve accuracy of the rules used to check expression validity
4242 - MINOR: sample: add missing ARGC_ entries
4243 - BUG/MINOR: vars: properly set the argument parsing context in the expression
4244 - DOC: configuration: remove wrong tcp-request examples in tcp-response
4245 - MEDIUM: vars: add a new "set-var-fmt" action
4246 - BUG/MEDIUM: vars: run over the correct list in release_store_rules()
4247 - BUG/MINOR: vars: truncate the variable name in error reports about scope.
4248 - BUG/MINOR: vars: do not talk about global section in CLI errors for set-var
4249 - CLEANUP: vars: name the temporary proxy "CFG" instead of "CLI" for global vars
4250 - MINOR: log: make log-format expressions completely usable outside of req/resp
4251 - MINOR: vars: add a "set-var-fmt" directive to the global section
4252 - MEDIUM: vars: also support format strings in CLI's "set var" command
4253 - CLEANUP: vars: factor out common code from vars_get_by_{desc,name}
4254 - MINOR: vars: make vars_get_by_* support an optional default value
4255 - MINOR: vars: make the vars() sample fetch function support a default value
4256 - BUILD: ot: add argument for default value to vars_get_by_name()
4257
Willy Tarreau446344c2021-08-28 13:46:11 +020042582021/08/28 : 2.5-dev5
4259 - MINOR: httpclient: initialize the proxy
4260 - MINOR: httpclient: implement a simple HTTP Client API
4261 - MINOR: httpclient/cli: implement a simple client over the CLI
4262 - MINOR: httpclient/cli: change the User-Agent to "HAProxy"
4263 - MEDIUM: ssl: Keep a reference to the client's certificate for use in logs
4264 - BUG/MEDIUM: h2: match absolute-path not path-absolute for :path
4265 - BUILD/MINOR: ssl: Fix compilation with OpenSSL 1.0.2
4266 - MINOR: server: check if srv is NULL in free_server()
4267 - MINOR: proxy: check if p is NULL in free_proxy()
4268 - BUG/MEDIUM: cfgparse: do not allocate IDs to automatic internal proxies
4269 - BUG/MINOR: http_client: make sure to preset the proxy's default settings
4270 - REGTESTS: http_upgrade: fix incorrect expectation on TCP->H1->H2
4271 - REGTESTS: abortonclose: after retries, 503 is expected, not close
4272 - REGTESTS: server: fix agent-check syntax and expectation
4273 - BUG/MINOR: httpclient: fix uninitialized sl variable
4274 - BUG/MINOR: httpclient/cli: change the appctx test in the callbacks
4275 - BUG/MINOR: httpclient: check if hdr_num is not 0
4276 - MINOR: httpclient: cleanup the include files
4277 - MINOR: hlua: take the global Lua lock inside a global function
4278 - MINOR: tools: add FreeBSD support to get_exec_path()
4279 - BUG/MINOR: systemd: ExecStartPre must use -Ws
4280 - MINOR: systemd: remove the ExecStartPre line in the unit file
4281 - MINOR: ssl: add an openssl version string parser
4282 - MINOR: cfgcond: implements openssl_version_atleast and openssl_version_before
4283 - CLEANUP: ssl: remove useless check on p in openssl_version_parser()
4284 - BUG/MINOR: stick-table: fix the sc-set-gpt* parser when using expressions
4285 - BUG/MINOR: httpclient: remove deinit of the httpclient
4286 - BUG/MEDIUM: base64: check output boundaries within base64{dec,urldec}
4287 - MINOR: httpclient: set verify none on the https server
4288 - MINOR: httpclient: add the server to the proxy
4289 - BUG/MINOR: httpclient: fix Host header
4290 - BUILD: httpclient: fix build without OpenSSL
4291 - CI: github-actions: remove obsolete options
4292 - CLEANUP: assorted typo fixes in the code and comments
4293 - MINOR: proc: setting the process to produce a core dump on FreeBSD.
4294 - BUILD: adopt script/build-ssl.sh for OpenSSL-3.0.0beta2
4295 - MINOR: server: return the next srv instance on free_server
4296 - BUG/MINOR: stats: use refcount to protect dynamic server on dump
4297 - MEDIUM: server: extend refcount for all servers
4298 - MINOR: server: define non purgeable server flag
4299 - MINOR: server: mark referenced servers as non purgeable
4300 - MINOR: server: mark servers referenced by LUA script as non purgeable
4301 - MEDIUM: server: allow to remove servers at runtime except non purgeable
4302 - BUG/MINOR: base64: base64urldec() ignores padding in output size check
4303 - REGTEST: add missing lua requirements on server removal test
4304 - REGTEST: fix haproxy required version for server removal test
4305 - BUG/MINOR: proxy: don't dump servers of internal proxies
4306 - REGTESTS: Use `feature cmd` for 2.5+ tests
4307 - REGTESTS: Remove REQUIRE_VERSION=1.5 from all tests
4308 - BUG/MINOR: resolvers: mark servers with name-resolution as non purgeable
4309 - MINOR: compiler: implement an ONLY_ONCE() macro
4310 - BUG/MINOR: lua: use strlcpy2() not strncpy() to copy sample keywords
4311 - MEDIUM: ssl: Capture more info from Client Hello
4312 - MINOR: sample: Expose SSL captures using new fetchers
4313 - MINOR: sample: Add be2dec converter
4314 - MINOR: sample: Add be2hex converter
4315 - MEDIUM: config: Deprecate tune.ssl.capture-cipherlist-size
4316 - BUG/MINOR: time: fix idle time computation for long sleeps
4317 - MINOR: time: add report_idle() to report process-wide idle time
4318 - BUG/MINOR: ebtree: remove dependency on incorrect macro for bits per long
4319 - BUILD: activity: use #ifdef not #if on USE_MEMORY_PROFILING
4320 - BUILD/MINOR: defaults: eliminate warning on MAXHOSTNAMELEN with -Wundef
4321 - BUILD/MINOR: ssl: avoid a build warning on LIBRESSL_VERSION with -Wundef
4322 - IMPORT: slz: silence a build warning with -Wundef
4323 - BUILD/MINOR: regex: avoid a build warning on USE_PCRE2 with -Wundef
4324
Willy Tarreau08d0f232021-08-17 14:08:55 +020043252021/08/17 : 2.5-dev4
4326 - MINOR: log: rename 'dontloglegacyconnerr' to 'log-error-via-logformat'
4327 - MINOR: doc: rename conn_status in `option httsplog`
4328 - MINOR: proxy: disabled takes a stopping and a disabled state
4329 - MINOR: stats: shows proxy in a stopped state
4330 - BUG/MINOR: server: fix race on error path of 'add server' CLI if track
4331 - CLEANUP: thread: fix fantaisist indentation of thread_harmless_till_end()
4332 - MINOR: threads: make thread_release() not wait for other ones to complete
4333 - MEDIUM: threads: add a stronger thread_isolate_full() call
4334 - MEDIUM: servers: make the server deletion code run under full thread isolation
4335 - BUG/MINOR: server: remove srv from px list on CLI 'add server' error
4336 - MINOR: activity/fd: remove the dead_fd counter
4337 - MAJOR: fd: get rid of the DWCAS when setting the running_mask
4338 - CLEANUP: fd: remove the now unused fd_set_running()
4339 - CLEANUP: fd: remove the now unneeded fd_mig_lock
4340 - BUG/MINOR: server: update last_change on maint->ready transitions too
4341 - MINOR: spoe: Add a pointer on the filter config in the spoe_agent structure
4342 - BUG/MEDIUM: spoe: Create a SPOE applet if necessary when the last one is released
4343 - BUG/MEDIUM: spoe: Fix policy to close applets when SPOE connections are queued
4344 - MINOR: server: unmark deprecated on enable health/agent cli
4345 - MEDIUM: task: implement tasklet kill
4346 - MINOR: server: initialize fields for dynamic server check
4347 - MINOR: check: allocate default check ruleset for every backends
4348 - MINOR: check: export check init functions
4349 - MINOR: check: do not increment global maxsock at runtime
4350 - MINOR: server: implement a refcount for dynamic servers
4351 - MEDIUM: check: implement check deletion for dynamic servers
4352 - MINOR: check: enable safe keywords for dynamic servers
4353 - MEDIUM: server: implement check for dynamic servers
4354 - MEDIUM: server: implement agent check for dynamic servers
4355 - REGTESTS: server: add dynamic check server test
4356 - MINOR: doc: specify ulimit-n usage for dynamic servers
4357 - REGTESTS: server: fix dynamic server with checks test
4358 - CI: travis-ci: temporarily disable arm64 builds
4359 - BUG/MINOR: check: test if server is not null in purge
4360 - MINOR: global: define MODE_STOPPING
4361 - BUG/MINOR: server: do not use refcount in free_server in stopping mode
4362 - ADMIN: dyncookie: implement a simple dynamic cookie calculator
4363 - BUG/MINOR: check: do not reset check flags on purge
4364 - BUG/MINOR: check: fix leak on add dynamic server with agent-check error
4365 - BUG/MEDIUM: check: fix leak on agent-check purge
4366 - BUG/MEDIUM: server: support both check/agent-check on a dynamic instance
4367 - BUG/MINOR: buffer: fix buffer_dump() formatting
4368 - MINOR: channel: remove an htx block from a channel
4369 - BUG/MINOR: tcpcheck: Properly detect pending HTTP data in output buffer
4370 - BUG/MINOR: stream: Don't release a stream if FLT_END is still registered
4371 - MINOR: lua: Add a flag on lua context to know the yield capability at run time
4372 - BUG/MINOR: lua: Yield in channel functions only if lua context can yield
4373 - BUG/MINOR: lua: Don't yield in channel.append() and channel.set()
4374 - MINOR: filters/lua: Release filters before the lua context
4375 - MINOR: lua: Add a function to get a reference on a table in the stack
4376 - MEDIUM: lua: Process buffer data using an offset and a length
4377 - MEDIUM: lua: Improve/revisit the lua api to manipulate channels
4378 - DOC: Improve the lua documentation
4379 - MEDIUM: filters/lua: Add support for dummy filters written in lua
4380 - MINOR: lua: Add a function to get a filter attached to a channel class
4381 - MINOR: lua: Add flags on the lua TXN to know the execution context
4382 - MEDIUM: filters/lua: Be prepared to filter TCP payloads
4383 - MEDIUM: filters/lua: Support declaration of some filter callback functions in lua
4384 - MEDIUM: filters/lua: Add HTTPMessage class to help HTTP filtering
4385 - MINOR: filters/lua: Add request and response HTTP messages in the lua TXN
4386 - MINOR: filters/lua: Support the HTTP filtering from filters written in lua
4387 - DOC: config: Fix 'http-response send-spoe-group' documentation
4388 - BUG/MINOR: lua: Properly check negative offset in Channel/HttpMessage functions
4389 - BUG/MINOR: lua: Properly catch alloc errors when parsing lua filter directives
4390 - BUG/MEDIUM: cfgcheck: verify existing log-forward listeners during config check
4391 - MINOR: cli: delare the CLI frontend as an internal proxy
4392 - MINOR: proxy: disable warnings for internal proxies
4393 - BUG/MINOR: filters: Always set FLT_END analyser when CF_FLT_ANALYZE flag is set
4394 - BUG/MINOR: lua/filters: Return right code when txn:done() is called
4395 - DOC: lua-api: Add documentation about lua filters
4396 - CI: Remove obsolete USE_SLZ=1 CI job
4397 - CLEANUP: assorted typo fixes in the code and comments
4398 - CI: github actions: relax OpenSSL-3.0.0 version comparision
4399 - BUILD: tools: get the absolute path of the current binary on NetBSD.
4400 - DOC: Minor typo fix - 'question mark' -> 'exclamation mark'
4401 - DOC/MINOR: fix typo in management document
4402 - MINOR: http: add a new function http_validate_scheme() to validate a scheme
4403 - BUG/MAJOR: h2: verify early that non-http/https schemes match the valid syntax
4404 - BUG/MAJOR: h2: verify that :path starts with a '/' before concatenating it
4405 - BUG/MAJOR: h2: enforce stricter syntax checks on the :method pseudo-header
4406 - BUG/MEDIUM: h2: give :authority precedence over Host
4407 - REGTESTS: add a test to prevent h2 desync attacks
4408
Willy Tarreau8441deb2021-08-01 18:19:51 +020044092021/08/01 : 2.5-dev3
4410 - BUG/MINOR: arg: free all args on make_arg_list()'s error path
4411 - BUG/MINOR: cfgcond: revisit the condition freeing mechanism to avoid a leak
4412 - MEDIUM: proxy: remove long-broken 'option http_proxy'
4413 - CLEANUP: http_ana: Remove now unused label from http_process_request()
4414 - MINOR: deinit: always deinit the init_mutex on failed initialization
4415 - BUG/MEDIUM: cfgcond: limit recursion level in the condition expression parser
4416 - BUG/MEDIUM: mworker: do not register an exit handler if exit is expected
4417 - BUG/MINOR: mworker: do not export HAPROXY_MWORKER_REEXEC across programs
4418 - BUILD/MINOR: memprof fix macOs build.
4419 - BUG/MEDIUM: ssl_sample: fix segfault for srv samples on invalid request
4420 - BUG/MINOR: stats: Add missing agent stats on servers
4421 - BUG/MINOR: check: fix the condition to validate a port-less server
4422 - BUILD: threads: fix pthread_mutex_unlock when !USE_THREAD
4423 - BUG/MINOR: resolvers: Use a null-terminated string to lookup in servers tree
4424 - MINOR: ssl: use __objt_* variant when retrieving counters
4425 - BUG/MINOR: systemd: must check the configuration using -Ws
4426 - BUG/MINOR: mux-h1: Obey dontlognull option for empty requests
4427 - BUG/MINOR: mux-h2: Obey dontlognull option during the preface
4428 - BUG/MINOR: mux-h1: Be sure to swap H1C to splice mode when rcv_pipe() is called
4429 - BUG/MEDIUM: mux-h2: Handle remaining read0 cases on partial frames
4430 - MINOR: proxy: rename PR_CAP_LUA to PR_CAP_INT
4431 - MINOR: mworker: the mworker CLI proxy is internal
4432 - MINOR: stats: don't output internal proxies (PR_CAP_INT)
4433 - CLEANUP: mworker: use the proxy helper functions in mworker_cli_proxy_create()
4434 - CLEANUP: mworker: PR_CAP already initialized with alloc_new_proxy()
4435 - BUG/MINOR: connection: Add missing error labels to conn_err_code_str
4436 - MINOR: connection: Add a connection error code sample fetch
4437 - MINOR: ssl: Enable error fetches in case of handshake error
4438 - MINOR: ssl: Add new ssl_fc_hsk_err sample fetch
4439 - MINOR: ssl: Define a default https log format
4440 - MEDIUM: connection: Add option to disable legacy error log
4441 - REGTESTS: ssl: Add tests for the connection and SSL error fetches
4442 - REGTESTS: ssl: ssl_errors.vtc does not work with old openssl version
4443 - BUG/MEDIUM: connection: close a rare race between idle conn close and takeover
4444 - BUG/MEDIUM: pollers: clear the sleeping bit after waking up, not before
4445 - BUG/MINOR: select: fix excess number of dead/skip reported
4446 - BUG/MINOR: poll: fix abnormally high skip_fd counter
4447 - BUG/MINOR: pollers: always program an update for migrated FDs
4448 - BUG/MINOR: fd: protect fd state harder against a concurrent takeover
4449 - DOC: internals: document the FD takeover process
4450 - MINOR: fd: update flags only once in fd_update_events()
4451 - MINOR: poll/epoll: move detection of RDHUP support earlier
4452 - REORG: fd: uninline fd_update_events()
4453 - MEDIUM: fd: rely more on fd_update_events() to detect changes
4454 - BUG/MINOR: freq_ctr: use stricter barriers between updates and readings
4455 - MEDIUM: atomic: simplify the atomic load/store/exchange operations
4456 - MEDIUM: atomic: relax the load/store barriers on x86_64
4457 - BUILD: opentracing: fixed build when using pkg-config utility
4458
Willy Tarreaubccc91d2021-07-17 12:35:11 +020044592021/07/17 : 2.5-dev2
4460 - BUILD/MEDIUM: tcp: set-mark support for OpenBSD
4461 - DOC: config: use CREATE USER for mysql-check
4462 - BUG/MINOR: stick-table: fix several printf sign errors dumping tables
4463 - BUG/MINOR: peers: fix data_type bit computation more than 32 data_types
4464 - MINOR: stick-table: make skttable_data_cast to use only std types
4465 - MEDIUM: stick-table: handle arrays of standard types into stick-tables
4466 - MEDIUM: peers: handle arrays of std types in peers protocol
4467 - DOC: stick-table: add missing documentation about gpt0 stored type
4468 - MEDIUM: stick-table: add the new array of gpt data_type
4469 - MEDIUM: stick-table: make the use of 'gpt' excluding the use of 'gpt0'
4470 - MEDIUM: stick-table: add the new arrays of gpc and gpc_rate
4471 - MEDIUM: stick-table: make the use of 'gpc' excluding the use of 'gpc0/1''
4472 - BUG/MEDIUM: sock: make sure to never miss early connection failures
4473 - BUG/MINOR: cli: fix server name output in "show fd"
4474 - Revert "MINOR: tcp-act: Add set-src/set-src-port for "tcp-request content" rules"
4475 - MEDIUM: stats: include disabled proxies that hold active sessions to stats
4476 - BUILD: stick-table: shut up invalid "uninitialized" warning in gcc 8.3
4477 - MINOR: http: implement http_get_scheme
4478 - MEDIUM: http: implement scheme-based normalization
4479 - MEDIUM: h1-htx: apply scheme-based normalization on h1 requests
4480 - MEDIUM: h2: apply scheme-based normalization on h2 requests
4481 - REGTESTS: add http scheme-based normalization test
4482 - BUILD: http_htx: fix ci compilation error with isdigit for Windows
4483 - MINOR: http: implement http uri parser
4484 - MINOR: http: use http uri parser for scheme
4485 - MINOR: http: use http uri parser for authority
4486 - REORG: http_ana: split conditions for monitor-uri in wait for request
4487 - MINOR: http: use http uri parser for path
4488 - BUG/MEDIUM: http_ana: fix crash for http_proxy mode during uri rewrite
4489 - MINOR: mux_h2: define config to disable h2 websocket support
4490 - CLEANUP: applet: remove unused thread_mask
4491 - BUG/MINOR: ssl: Default-server configuration ignored by server
4492 - BUILD: add detection of missing important CFLAGS
4493 - BUILD: lua: silence a build warning with TCC
4494 - MINOR: srv: extract tracking server config function
4495 - MINOR: srv: do not allow to track a dynamic server
4496 - MEDIUM: server: support track keyword for dynamic servers
4497 - REGTESTS: test track support for dynamic servers
4498 - MINOR: init: verify that there is a single word on "-cc"
4499 - MINOR: init: make -cc support environment variables expansion
4500 - MINOR: arg: add a free_args() function to free an args array
4501 - CLEANUP: config: use free_args() to release args array in cfg_eval_condition()
4502 - CLEANUP: hlua: use free_args() to release args arrays
4503 - REORG: config: move the condition preprocessing code to its own file
4504 - MINOR: cfgcond: start to split the condition parser to introduce terms
4505 - MEDIUM: cfgcond: report invalid trailing chars after expressions
4506 - MINOR: cfgcond: remerge all arguments into a single line
4507 - MINOR: cfgcond: support negating conditional expressions
4508 - MINOR: cfgcond: make the conditional term parser automatically allocate nodes
4509 - MINOR: cfgcond: insert an expression between the condition and the term
4510 - MINOR: cfgcond: support terms made of parenthesis around expressions
4511 - REGTEST: make check_condition.vtc fail as soon as possible
4512 - REGTESTS: add more complex check conditions to check_conditions.vtc
4513 - BUG/MEDIUM: init: restore behavior of command-line "-m" for memory limitation
4514
Willy Tarreau96a2f502021-06-30 16:16:14 +020045152021/06/30 : 2.5-dev1
4516 - CLEANUP: ssl: Move ssl_store related code to ssl_ckch.c
4517 - MINOR: ssl: Allow duplicated entries in the cafile_tree
4518 - MEDIUM: ssl: Chain ckch instances in ca-file entries
4519 - MINOR: ssl: Add reference to default ckch instance in bind_conf
4520 - MINOR: ssl: Add helper functions to create/delete cafile entries
4521 - MEDIUM: ssl: Add a way to load a ca-file content from memory
4522 - MINOR: ssl: Add helper function to add cafile entries
4523 - MINOR: ssl: Ckch instance rebuild and cleanup factorization in CLI handler
4524 - MEDIUM: ssl: Add "set+commit ssl ca-file" CLI commands
4525 - REGTESTS: ssl: Add new ca-file update tests
4526 - MINOR: ssl: Add "abort ssl ca-file" CLI command
4527 - MINOR: ssl: Add a cafile_entry type field
4528 - MINOR: ssl: Refactorize the "show certificate details" code
4529 - MEDIUM: ssl: Add "show ssl ca-file" CLI command
4530 - MEDIUM: ssl: Add "new ssl ca-file" CLI command
4531 - MINOR: ssl: Add "del ssl ca-file" CLI command
4532 - REGTESTS: ssl: Add "new/del ssl ca-file" tests
4533 - DOC: ssl: Add documentation about CA file hot update commands
4534 - DOC: internals: update the SSL architecture schema
4535 - MINOR: ssl: Chain instances in ca-file entries
4536 - MEDIUM: ssl: Add "set+commit ssl crl-file" CLI commands
4537 - MEDIUM: ssl: Add "new+del crl-file" CLI commands
4538 - MINOR: ssl: Add "abort ssl crl-file" CLI command
4539 - MEDIUM: ssl: Add "show ssl crl-file" CLI command
4540 - REGTESTS: ssl: Add "new/del ssl crl-file" tests
4541 - REGTESTS: ssl: Add "set/commit ssl crl-file" test
4542 - DOC: ssl: Add documentation about CRL file hot update commands
4543 - BUILD/MINOR: ssl: Fix compilation with SSL enabled
4544 - BUILD/MINOR: ssl: Fix compilation with OpenSSL 1.0.2
4545 - CI: introduce scripts/build-vtest.sh for installing VTest
4546 - CLEANUP: ssl: Fix coverity issues found in CA file hot update code
4547 - CI: github actions: add OpenTracing builds
4548 - BUG/MEDIUM: ebtree: Invalid read when looking for dup entry
4549 - BUG/MAJOR: server: prevent deadlock when using 'set maxconn server'
4550 - BUILD/MINOR: opentracing: fixed build when using clang
4551 - BUG/MEDIUM: filters: Exec pre/post analysers only one time per filter
4552 - BUG/MINOR: http-comp: Preserve HTTP_MSGF_COMPRESSIONG flag on the response
4553 - MINOR: map/acl: print the count of all the map/acl entries in "show map/acl"
4554 - CLEANUP: pattern: remove export of non-existent function pattern_delete()
4555 - MINOR: h1-htx: Update h1 parsing functions to return result as a size_t
4556 - MEDIUM: h1-htx: Adapt H1 data parsing to copy wrapping data in one call
4557 - MINOR: mux-h1/mux-fcgi: Don't needlessly loop on data parsing
4558 - MINOR: h1-htx: Move HTTP chunks parsing into a dedicated function
4559 - MEDIUM: h1-htx: Split function to parse a chunk and the loop on the buffer
4560 - MEDIUM: h1-htx: Add a function to parse contiguous small chunks
4561 - MINOR: h1-htx: Use a correlation table to speed-up small chunks parsing
4562 - MINOR: buf: Add function to realign a buffer with a specific head position
4563 - MINOR: muxes/h1-htx: Realign input buffer using b_slow_realign_ofs()
4564 - CLEANUP: mux-h1: Rename functions parsing input buf and filling output buf
4565 - Revert "MEDIUM: http-ana: Deal with L7 retries in HTTP analysers"
4566 - BUG/MINOR: http-ana: Send the right error if max retries is reached on L7 retry
4567 - BUG/MINOR: http-ana: Handle L7 retries on refused early data before K/A aborts
4568 - MINOR: http-ana: Perform L7 retries because of status codes in response analyser
4569 - MINOR: cfgparse: Fail when encountering extra arguments in macro
4570 - DOC: intro: Fix typo in starter guide
4571 - BUG/MINOR: server: Missing calloc return value check in srv_parse_source
4572 - BUG/MINOR: peers: Missing calloc return value check in peers_register_table
4573 - BUG/MINOR: ssl: Missing calloc return value check in ssl_init_single_engine
4574 - BUG/MINOR: http: Missing calloc return value check in parse_http_req_capture
4575 - BUG/MINOR: proxy: Missing calloc return value check in proxy_parse_declare
4576 - BUG/MINOR: proxy: Missing calloc return value check in proxy_defproxy_cpy
4577 - BUG/MINOR: http: Missing calloc return value check while parsing tcp-request/tcp-response
4578 - BUG/MINOR: http: Missing calloc return value check while parsing tcp-request rule
4579 - BUG/MINOR: compression: Missing calloc return value check in comp_append_type/algo
4580 - BUG/MINOR: worker: Missing calloc return value check in mworker_env_to_proc_list
4581 - BUG/MINOR: http: Missing calloc return value check while parsing redirect rule
4582 - BUG/MINOR: http: Missing calloc return value check in make_arg_list
4583 - BUG/MINOR: proxy: Missing calloc return value check in chash_init_server_tree
4584 - CLEANUP: http-ana: Remove useless if statement about L7 retries
4585 - BUG/MAJOR: stream-int: Release SI endpoint on server side ASAP on retry
4586 - MINOR: backend: Don't release SI endpoint anymore in connect_server()
4587 - BUG/MINOR: vars: Be sure to have a session to get checks variables
4588 - DOC/MINOR: move uuid in the configuration to the right alphabetical order
4589 - CLEANUP: mux-fcgi: Don't needlessly store result of data/trailers parsing
4590 - BUILD: fix compilation for OpenSSL-3.0.0-alpha17
4591 - MINOR: http-ana: Use -1 status for client aborts during queuing and connect
4592 - REGTESTS: Fix http_abortonclose.vtc to support -1 status for some client aborts
4593 - CLEANUP: backend: fix incorrect comments on locking conditions for lb functions
4594 - CLEANUP: reg-tests: Remove obsolete no-htx parameter for reg-tests
4595 - CI: github actions: add OpenSSL-3.0.0 builds
4596 - CI: github actions: -Wno-deprecated-declarations with OpenSSL 3.0.0
4597 - MINOR: errors: allow empty va_args for diag variadic macro
4598 - REORG: errors: split errors reporting function from log.c
4599 - CLEANUP: server: fix cosmetic of error message on sni parsing
4600 - MEDIUM: errors: implement user messages buffer
4601 - MINOR: log: do not discard stderr when starting is over
4602 - MEDIUM: errors: implement parsing context type
4603 - MINOR: errors: use user messages context in print_message
4604 - MINOR: log: display exec path on first warning
4605 - MINOR: errors: specify prefix "config" for parsing output
4606 - MINOR: log: define server user message format
4607 - REORG: server: use parsing ctx for server parsing
4608 - REORG: config: use parsing ctx for server config check
4609 - MINOR: server: use parsing ctx for server init addr
4610 - MINOR: server: use ha_alert in server parsing functions
4611 - DOC: use the req.ssl_sni in examples
4612 - CLEANUP: cfgparse: Remove duplication of `MAX_LINE_ARGS + 1`
4613 - CLEANUP: tools: Make errptr const in `parse_line()`
4614 - MINOR: haproxy: Add `-cc` argument
4615 - BUG: errors: remove printf positional args for user messages context
4616 - CI: Make matrix.py executable and add shebang
4617 - BUILD: make tune.ssl.keylog available again
4618 - BUG/MINOR: ssl: OCSP stapling does not work if expire too far in the future
4619 - Revert "BUG/MINOR: opentracing: initialization after establishing daemon mode"
4620 - BUG/MEDIUM: opentracing: initialization before establishing daemon and/or chroot mode
4621 - SCRIPTS: opentracing: enable parallel builds in build-ot.sh
4622 - BUG/MEDIUM: compression: Fix loop skipping unused blocks to get the next block
4623 - BUG/MEDIUM: compression: Properly get the next block to iterate on payload
4624 - BUG/MEDIUM: compression: Add a flag to know the filter is still processing data
4625 - MINOR: ssl: Keep the actual key length in the certificate_ocsp structure
4626 - MINOR: ssl: Add new "show ssl ocsp-response" CLI command
4627 - MINOR: ssl: Add the OCSP entry key when displaying the details of a certificate
4628 - MINOR: ssl: Add the "show ssl cert foo.pem.ocsp" CLI command
4629 - REGTESTS: ssl: Add "show ssl ocsp-response" test
4630 - BUG/MINOR: server: explicitly set "none" init-addr for dynamic servers
4631 - BUG/MINOR: pools: fix a possible memory leak in the lockless pool_flush()
4632 - BUG/MINOR: pools: make DEBUG_UAF always write to the to-be-freed location
4633 - MINOR: pools: do not maintain the lock during pool_flush()
4634 - MINOR: pools: call malloc_trim() under thread isolation
4635 - MEDIUM: pools: use a single pool_gc() function for locked and lockless
4636 - BUG/MAJOR: pools: fix possible race with free() in the lockless variant
4637 - CLEANUP: pools: remove now unused seq and pool_free_list
4638 - MEDIUM: pools: remove the locked pools implementation
4639 - BUILD: ssl: Fix compilation with BoringSSL
4640 - BUG/MEDIUM: errors: include missing obj_type file
4641 - REGTESTS: ssl: show_ssl_ocspresponce.vtc is broken with BoringSSL
4642 - BUG/MAJOR: htx: Fix htx_defrag() when an HTX block is expanded
4643 - BUG/MINOR: mux-fcgi: Expose SERVER_SOFTWARE parameter by default
4644 - BUG/MINOR: h1-htx: Fix a signess bug with char data type when parsing chunk size
4645 - CLEANUP: l7-retries: do not test the buffer before calling b_alloc()
4646 - BUG/MINOR: resolvers: answser item list was randomly purged or errors
4647 - MEDIUM: resolvers: add a ref on server to the used A/AAAA answer item
4648 - MEDIUM: resolvers: add a ref between servers and srv request or used SRV record
4649 - BUG/MINOR: server-state: load SRV resolution only if params match the config
4650 - MINOR: config: remove support for deprecated option "tune.chksize"
4651 - MINOR: config: completely remove support for "no option http-use-htx"
4652 - MINOR: log: remove the long-deprecated early log-format tags
4653 - MINOR: http: remove the long deprecated "set-cookie()" sample fetch function
4654 - MINOR: config: reject long-deprecated "option forceclose"
4655 - MINOR: config: remove deprecated option "http-tunnel"
4656 - MEDIUM: proxy: remove the deprecated "grace" keyword
4657 - MAJOR: config: remove parsing of the global "nbproc" directive
4658 - BUILD: init: remove initialization of multi-process thread mappings
4659 - BUILD: log: remove unused fmt_directive()
4660 - REGTESTS: Remove REQUIRE_VERSION=1.6 from all tests
4661 - REGTESTS: Remove REQUIRE_VERSION=1.7 from all tests
4662 - CI: github actions: enable alpine/musl builds
4663 - BUG/MAJOR: resolvers: segfault using server template without SRV RECORDs
4664 - DOC: lua: Add a warning about buffers modification in HTTP
4665 - MINOR: ssl: Use OpenSSL's ASN1_TIME convertor when available
4666 - BUG/MINOR: stick-table: insert srv in used_name tree even with fixed id
4667 - BUG/MEDIUM: server: extend thread-isolate over much of CLI 'add server'
4668 - BUG/MEDIUM: server: clear dynamic srv on delete from proxy id/name trees
4669 - BUG/MEDIUM: server: do not forget to generate the dynamic servers ids
4670 - BUG/MINOR: server: do not keep an invalid dynamic server in px ids tree
4671 - BUG/MEDIUM: server: do not auto insert a dynamic server in px addr_node
4672 - BUG/MEDIUM: shctx: use at least thread-based locking on USE_PRIVATE_CACHE
4673 - BUG/MINOR: ssl: use atomic ops to update global shctx stats
4674 - BUG/MINOR: mworker: fix typo in chroot error message
4675 - CLEANUP: global: remove unused definition of stopping_task[]
4676 - MEDIUM: init: remove the loop over processes during init
4677 - MINOR: mworker: remove the initialization loop over processes
4678 - CLEANUP: global: remove the nbproc field from the global structure
4679 - CLEANUP: global: remove pid_bit and all_proc_mask
4680 - MEDIUM: global: remove dead code from nbproc/bind_proc removal
4681 - MEDIUM: config: simplify cpu-map handling
4682 - MEDIUM: cpu-set: make the proc a single bit field and not an array
4683 - CLEANUP: global: remove unused definition of MAX_PROCS
4684 - MEDIUM: global: remove the relative_pid from global and mworker
4685 - DOC: update references to process numbers in cpu-map and bind-process
4686 - MEDIUM: config: warn about "bind-process" deprecation
4687 - CLEANUP: shctx: remove the different inter-process locking techniques
4688 - BUG/MAJOR: queue: set SF_ASSIGNED when setting strm->target on dequeue
4689 - MINOR: backend: only skip LB when there are actual connections
4690 - BUG/MINOR: mux-h1: do not skip the error response on bad requests
4691 - MINOR: connection: add helper conn_append_debug_info()
4692 - MINOR: mux-h2/trace: report a few connection-level info during h2_init()
4693 - CLEANUP: mux-h2/traces: better align user messages
4694 - BUG/MINOR: stats: make "show stat typed desc" work again
4695 - MINOR: mux-h2: obey http-ignore-probes during the preface
4696 - BUG/MINOR: mux-h2/traces: bring back the lost "rcvd H2 REQ" trace
4697 - BUG/MINOR: mux-h2/traces: bring back the lost "sent H2 REQ/RES" traces
4698 - CLEANUP: assorted typo fixes in the code and comments
4699 - CI: Replace the requirement for 'sudo' with a call to 'ulimit -n'
4700 - REGTESTS: Replace REQUIRE_VERSION=2.5 with 'haproxy -cc'
4701 - REGTESTS: Replace REQUIRE_OPTIONS with 'haproxy -cc' for 2.5+ tests
4702 - REGTESTS: Replace REQUIRE_BINARIES with 'command -v'
4703 - REGTESTS: Remove support for REQUIRE_BINARIES
4704 - CI: ssl: enable parallel builds for OpenSSL on Linux
4705 - CI: ssl: do not needlessly build the OpenSSL docs
4706 - CI: ssl: keep the old method for ancient OpenSSL versions
4707 - CLEANUP: server: a separate function for initializing the per_thr field
4708 - BUG/MINOR: server: Forbid to set fqdn on the CLI if SRV resolution is enabled
4709 - BUG/MEDIUM: server/cli: Fix ABBA deadlock when fqdn is set from the CLI
4710 - MINOR: resolvers: Clean server in a dedicated function when removing a SRV item
4711 - MINOR: resolvers: Remove server from named_servers tree when removing a SRV item
4712 - BUG/MEDIUM: resolvers: Add a task on servers to check SRV resolution status
4713 - BUG/MINOR: backend: restore the SF_SRV_REUSED flag original purpose
4714 - BUG/MINOR: backend: do not set sni on connection reuse
4715 - BUG/MINOR: resolvers: Use resolver's lock in resolv_srvrq_expire_task()
4716 - BUG/MINOR: server/cli: Fix locking in function processing "set server" command
4717 - BUG/MINOR: cache: Correctly handle existing-but-empty 'accept-encoding' header
4718 - MINOR: ssl: fix typo in usage for 'new ssl ca-file'
4719 - MINOR: ssl: always initialize random generator
4720 - MINOR: ssl: check allocation in ssl_sock_init_srv
4721 - MINOR: ssl: check allocation in parse ciphers/ciphersuites/verifyhost
4722 - MINOR: ssl: check allocation in parse npn/sni
4723 - MINOR: server: disable CLI 'set server ssl' for dynamic servers
4724 - MINOR: ssl: render file-access optional on server crt loading
4725 - MINOR: ssl: split parse functions for alpn/check-alpn
4726 - MINOR: ssl: support ca-file arg for dynamic servers
4727 - MINOR: ssl: support crt arg for dynamic servers
4728 - MINOR: ssl: support crl arg for dynamic servers
4729 - MINOR: ssl: enable a series of ssl keywords for dynamic servers
4730 - MINOR: ssl: support ssl keyword for dynamic servers
4731 - REGTESTS: server: test ssl support for dynamic servers
4732 - MINOR: queue: update the stream's pend_pos before queuing it
4733 - CLEANUP: Prevent channel-t.h from being detected as C++ by GitHub
4734 - BUG/MAJOR: server: fix deadlock when changing maxconn via agent-check
4735 - REGTESTS: fix maxconn update with agent-check
4736 - MEDIUM: queue: make pendconn_process_next_strm() only return the pendconn
4737 - MINOR: queue: update proxy->served once out of the loop
4738 - MEDIUM: queue: refine the locking in process_srv_queue()
4739 - MINOR: lb/api: remove the locked argument from take_conn/drop_conn
4740 - MINOR: queue: create a new structure type "queue"
4741 - MINOR: proxy: replace the pendconns-related stuff with a struct queue
4742 - MINOR: server: replace the pendconns-related stuff with a struct queue
4743 - MEDIUM: queue: use a dedicated lock for the queues
4744 - MEDIUM: queue: simplify again the process_srv_queue() API
4745 - MINOR: queue: factor out the proxy/server queuing code
4746 - MINOR: queue: use atomic-ops to update the queue's index
4747 - MEDIUM: queue: determine in process_srv_queue() if the proxy is usable
4748 - MEDIUM: queue: move the queue lock manipulation to pendconn_process_next_strm()
4749 - MEDIUM: queue: unlock as soon as possible
4750 - MINOR: queue: make pendconn_first() take the lock by itself
4751 - CLEANUP: backend: remove impossible case of round-robin + consistent hash
4752 - MINOR: tcp-act: Add set-src/set-src-port for "tcp-request content" rules
4753 - DOC: config: Add missing actions in "tcp-request session" documentation
4754 - CLEANUP: dns: Remove a forgotten debug message
4755 - DOC: Replace issue templates by issue forms
4756 - Revert "MINOR: queue: make pendconn_first() take the lock by itself"
4757 - Revert "MEDIUM: queue: unlock as soon as possible"
4758 - Revert "MEDIUM: queue: move the queue lock manipulation to pendconn_process_next_strm()"
4759 - Revert "MEDIUM: queue: determine in process_srv_queue() if the proxy is usable"
4760 - Revert "MINOR: queue: use atomic-ops to update the queue's index"
4761 - Revert "MINOR: queue: factor out the proxy/server queuing code"
4762 - Revert "MEDIUM: queue: simplify again the process_srv_queue() API"
4763 - Revert "MEDIUM: queue: use a dedicated lock for the queues"
4764 - Revert "MEDIUM: queue: refine the locking in process_srv_queue()"
4765 - Revert "MINOR: queue: update proxy->served once out of the loop"
4766 - Revert "MEDIUM: queue: make pendconn_process_next_strm() only return the pendconn"
4767 - MEDIUM: queue: update px->served and lb's take_conn once per loop
4768 - MEDIUM: queue: use a dedicated lock for the queues (v2)
4769 - MEDIUM: queue: simplify again the process_srv_queue() API (v2)
4770 - MEDIUM: queue: determine in process_srv_queue() if the proxy is usable (v2)
4771 - MINOR: queue: factor out the proxy/server queuing code (v2)
4772 - MINOR: queue: use atomic-ops to update the queue's index (v2)
4773 - MEDIUM: queue: take the proxy lock only during the px queue accesses
4774 - MEDIUM: queue: use a trylock on the server's queue
4775 - MINOR: queue: add queue_init() to initialize a queue
4776 - MINOR: queue: add a pointer to the server and the proxy in the queue
4777 - MINOR: queue: store a pointer to the queue into the pendconn
4778 - MINOR: queue: remove the px/srv fields from pendconn
4779 - MINOR: queue: simplify pendconn_unlink() regarding srv vs px
4780 - BUG: backend: stop looking for queued connections once there's no more
4781 - BUG/MINOR: queue/debug: use the correct lock labels on the queue lock
4782 - BUG/MINOR: resolvers: Always attach server on matching record on resolution
4783 - BUG/MINOR: resolvers: Reset server IP when no ip is found in the response
4784 - MINOR: resolvers: Reset server IP on error in resolv_get_ip_from_response()
4785 - BUG/MINOR: checks: return correct error code for srv_parse_agent_check
4786 - BUILD: Makefile: fix linkage for Haiku.
4787 - BUG/MINOR: tcpcheck: Fix numbering of implicit HTTP send/expect rules
4788 - MINOR: http-act/tcp-act: Add "set-log-level" for tcp content rules
4789 - MINOR: http-act/tcp-act: Add "set-nice" for tcp content rules
4790 - MINOR: http-act/tcp-act: Add "set-mark" and "set-tos" for tcp content rules
4791 - CLEANUP: tcp-act: Sort action lists
4792 - BUILD/MEDIUM: tcp: set-mark setting support for FreeBSD.
4793 - BUILD: tcp-act: avoid warning when set-mark / set-tos are not supported
4794 - BUG/MINOR: mqtt: Fix parser for string with more than 127 characters
4795 - BUG/MINOR: mqtt: Support empty client ID in CONNECT message
4796 - BUG/MEDIUM: resolvers: Make 1st server of a template take part to SRV resolution
4797 - CLEANUP: peers: re-write intdecode function comment.
4798
Willy Tarreau1f973062021-05-14 09:36:37 +020047992021/05/14 : 2.5-dev0
4800 - MINOR: version: it's development again
4801
Willy Tarreau6cbbecf2021-05-14 09:03:30 +020048022021/05/14 : 2.4.0
4803 - BUG/MINOR: http_fetch: fix possible uninit sockaddr in fetch_url_ip/port
4804 - CLEANUP: cli/activity: Remove double spacing in set profiling command
4805 - CI: Build VTest with clang
4806 - CI: extend spellchecker whitelist, add "ists" as well
4807 - CLEANUP: assorted typo fixes in the code and comments
4808 - BUG/MINOR: memprof: properly account for differences for realloc()
4809 - MINOR: memprof: also report the method used by each call
4810 - MINOR: memprof: also report the totals and delta alloc-free
4811 - CLEANUP: pattern: remove the unused and dangerous pat_ref_reload()
4812 - BUG/MINOR: http_act: Fix normalizer names in error messages
4813 - MINOR: uri_normalizer: Add `fragment-strip` normalizer
4814 - MINOR: uri_normalizer: Add `fragment-encode` normalizer
4815 - IMPORT: slz: use the generic function for the last bytes of the crc32
4816 - IMPORT: slz: do not produce the crc32_fast table when CRC is natively supported
4817 - BUILD/MINOR: opentracing: fixed compilation with filter enabled
4818 - BUILD: makefile: add a few popular ARMv8 CPU targets
4819 - BUG/MEDIUM: stick_table: fix crash when using tcp smp_fetch_src
4820 - REGTESTS: stick-table: add src_conn_rate test
4821 - CLEANUP: stick-table: remove a leftover of an old keyword declaration
4822 - BUG/MINOR: stats: fix lastchk metric that got accidently lost
4823 - EXAMPLES: add a "basic-config-edge" example config
4824 - EXAMPLES: add a trivial config for quick testing
4825 - DOC: management: Correct example reload command in the document
4826 - Revert "CI: Build VTest with clang"
4827 - MINOR: activity/cli: optionally support sorting by address on "show profiling"
4828 - DEBUG: ssl: export ssl_sock_close() to see its symbol resolved in profiling
4829 - BUG/MINOR: lua/vars: prevent get_var() from allocating a new name
4830 - DOC: config: Fix configuration example for mqtt
4831 - BUG/MAJOR: config: properly initialize cpu_map.thread[] up to MAX_THREADS
4832 - BUILD: config: avoid a build warning on numa_detect_topology() without threads
4833 - DOC: update min requirements in INSTALL
4834 - IMPORT: slz: use inttypes.h instead of stdint.h
4835 - BUILD: sample: use strtoll() instead of atoll()
4836 - MINOR: version: mention that it's LTS now.
4837
Willy Tarreau46b93af2021-05-10 07:50:26 +020048382021/05/10 : 2.4-dev19
4839 - BUG/MINOR: hlua: Don't rely on top of the stack when using Lua buffers
4840 - BUG/MEDIUM: cli: prevent memory leak on write errors
4841 - BUG/MINOR: ssl/cli: fix a lock leak when no memory available
4842 - MINOR: debug: add a new "debug dev sym" command in expert mode
4843 - MINOR: pools/debug: slightly relax DEBUG_DONT_SHARE_POOLS
4844 - CI: Github Actions: switch to LibreSSL-3.3.3
4845 - MINOR: srv: close all idle connections on shutdown
4846 - MINOR: connection: move session_list member in a union
4847 - MEDIUM: mux_h1: release idling frontend conns on soft-stop
4848 - MEDIUM: connection: close front idling connection on soft-stop
4849 - MINOR: tools: add functions to retrieve the address of a symbol
4850 - CLEANUP: activity: mark the profiling and task_profiling_mask __read_mostly
4851 - MINOR: activity: add a "memory" entry to "profiling"
4852 - MINOR: activity: declare the storage for memory usage statistics
4853 - MEDIUM: activity: collect memory allocator statistics with USE_MEMORY_PROFILING
4854 - MINOR: activity: clean up the show profiling io_handler a little bit
4855 - MINOR: activity: make "show profiling" support a few arguments
4856 - MINOR: activity: make "show profiling" also dump the memoery usage
4857 - MINOR: activity: add the profiling.memory global setting
4858 - BUILD: makefile: add new option USE_MEMORY_PROFILING
4859 - MINOR: channel: Rely on HTX version if appropriate in channel_may_recv()
4860 - BUG/MINOR: stream-int: Don't block reads in si_update_rx() if chn may receive
4861 - MINOR: conn-stream: Force mux to wait for read events if abortonclose is set
4862 - MEDIUM: mux-h1: Don't block reads when waiting for the other side
4863 - BUG/MEDIUM: mux-h1: Properly report client close if abortonclose option is set
4864 - REGTESTS: Add script to test abortonclose option
4865 - MINOR: mux-h1: clean up conditions to enabled and disabled splicing
4866 - MINOR: mux-h1: Subscribe for sends if output buffer is not empty in h1_snd_pipe
4867 - MINOR: mux-h1: Always subscribe for reads when splicing is disabled
4868 - MEDIUM: mux-h1: Wake H1 stream when both sides a synchronized
4869 - CLEANUP: mux-h1: rename WAIT_INPUT/WAIT_OUTPUT flags
4870 - MINOR: mux-h1: Manage processing blocking flags on the H1 stream
4871 - BUG/MINOR: stream: Decrement server current session counter on L7 retry
4872 - BUG/MINOR: config: fix uninitialized initial state in ".if" block evaluator
4873 - BUG/MINOR: config: add a missing "ELIF_TAKE" test for ".elif" condition evaluator
4874 - BUG/MINOR: config: .if/.elif should also accept negative integers
4875 - MINOR: config: centralize the ".if"/".elif" condition parser and evaluator
4876 - MINOR: config: keep up-to-date current file/line/section in the global struct
4877 - MINOR: config: support some pseudo-variables for file/line/section
4878 - BUILD: activity: do not include malloc.h
4879 - MINOR: arg: improve the error message on missing closing parenthesis
4880 - MINOR: global: export the build features string list
4881 - MINOR: global: add version comparison functions
4882 - MINOR: config: improve .if condition error reporting
4883 - MINOR: config: make cfg_eval_condition() support predicates with arguments
4884 - MINOR: config: add predicate "defined()" to conditional expression blocks
4885 - MINOR: config: add predicates "streq()" and "strneq()" to conditional expressions
4886 - MINOR: config: add predicate "feature" to detect certain built-in features
4887 - MINOR: config: add predicates "version_atleast" and "version_before" to cond blocks
4888 - BUG/MINOR: activity: use the new pointer to calculate the new size in realloc()
4889 - BUG/MINOR: stream: properly clear the previous error mask on L7 retries
4890 - MEDIUM: log: slightly refine the output format of alerts/warnings/etc
4891 - MINOR: config: add a new message directive: .diag
4892 - CLEANUP: cli/tree-wide: properly re-align the CLI commands' help messages
4893 - BUG/MINOR: stream: Reset stream final state and si error type on L7 retry
4894 - BUG/MINOR: checks: Handle synchronous connect when a tcpcheck is started
4895 - BUG/MINOR: checks: Reschedule check on observe mode only if fastinter is set
4896 - MINOR: global: define tainted flag
4897 - MINOR: cfgparse: add a new field flags in cfg_keyword
4898 - MINOR: cfgparse: implement experimental config keywords
4899 - MINOR: action: replace match_pfx by a keyword flags field
4900 - MINOR: action: implement experimental actions
4901 - MINOR: cli: set tainted when using CLI expert/experimental mode
4902 - MINOR: stats: report tainted on show info
4903 - MINOR: http_act: mark normalize-uri as experimental
4904 - BUILD: fix usage of ha_alert without format string
4905 - MINOR: proxy: define PR_CAP_LB
4906 - BUG/MINOR: server: do not report diag for peer servers with null weight
4907 - DOC: ssl: Extra files loading now works for backends too
4908 - ADDONS: make addons/ discoverable by git via .gitignore
4909 - DOC: ssl: Add information about crl-file option
4910 - MINOR: sample: improve error reporting on missing arg to strcmp() converter
4911 - DOC: management: mention that some fields may be emitted as floats
4912 - MINOR: tools: implement trimming of floating point numbers
4913 - MINOR: tools: add a float-to-ascii conversion function
4914 - MINOR: freq_ctr: add new functions to report float measurements
4915 - MINOR: stats: avoid excessive padding of float values with trailing zeroes
4916 - MINOR: stats: add the HTML conversion for float types
4917 - MINOR: stats: pass the appctx flags to stats_fill_info()
4918 - MINOR: stats: support an optional "float" option to "show info"
4919 - MINOR: stats: use tv_remain() to precisely compute the uptime
4920 - MINOR: stats: report uptime and start time as floats with subsecond resolution
4921 - MINOR: stats: make "show info" able to report rates as floats when asked
4922 - MINOR: config: mark tune.fd.edge-triggered as experimental
4923 - REORG: vars: move the "proc" scope variables out of the global struct
4924 - REORG: threads: move all_thread_mask() to thread.h
4925 - BUILD: wdt: include signal-t.h
4926 - BUILD: auth: include missing list.h
4927 - REORG: mworker: move proc_self from global to mworker
4928 - BUILD: ssl: ssl_utils requires chunk.h
4929 - BUILD: config: cfgparse-ssl.c needs tools.h
4930 - BUILD: wurfl: wurfl.c needs tools.h
4931 - BUILD: spoe: flt_spoe.c needs tools.h
4932 - BUILD: promex: service-prometheus.c needs tools.h
4933 - BUILD: resolvers: include tools.h
4934 - BUILD: config: include tools.h in cfgparse-listen.c
4935 - BUILD: htx: include tools.h in http_htx.c
4936 - BUILD: proxy: include tools.h in proxy.c
4937 - BUILD: session: include tools.h in session.c
4938 - BUILD: cache: include tools.h in cache.c
4939 - BUILD: sink: include tools.h in sink.c
4940 - BUILD: connection: include tools.h in connection.c
4941 - BUILD: server-state: include tools.h from server_state.c
4942 - BUILD: dns: include tools.h in dns.c
4943 - BUILD: payload: include tools.h in payload.c
4944 - BUILD: vars: include tools.h in vars.c
4945 - BUILD: compression: include tools.h in compression.c
4946 - BUILD: mworker: include tools.h from mworker.c
4947 - BUILD: queue: include tools.h from queue.c
4948 - BUILD: udp: include tools.h from proto_udp.c
4949 - BUILD: stick-table: include freq_ctr.h from stick_table.h
4950 - BUILD: server: include tools.h from server.c
4951 - BUILD: server: include missing proxy.h in server.c
4952 - BUILD: sink: include proxy.h in sink.c
4953 - BUILD: mworker: include proxy.h in mworker.c
4954 - BUILD: filters: include proxy.h in filters.c
4955 - BUILD: fcgi-app: include proxy.h in fcgi-app.c
4956 - BUILD: connection: move list_mux_proto() to connection.c
4957 - REORG: stick-table: uninline stktable_alloc_data_type()
4958 - REORG: stick-table: move composite address functions to stick_table.h
4959 - REORG: config: uninline warnifnotcap() and failifnotcap()
4960 - BUILD: task: remove unused includes from task.c
4961 - MINOR: task: stop including stream.h from task.c
4962 - BUILD: connection: stop including listener-t.h
4963 - BUILD: hlua: include proxy.h from hlua.c
4964 - BUILD: mux-h1: include proxy.h from mux-h1.c
4965 - BUILD: mux-fcgi: include proxy.h from mux-fcgi.c
4966 - BUILD: listener: include proxy.h from listener.c
4967 - BUILD: http-rules: include proxy.h from http_rules.c
4968 - BUILD: thread: include log.h from thread.c
4969 - BUILD: comp: include proxy.h from flt_http_comp.c
4970 - BUILD: fd: include log.h from fd.c
4971 - BUILD: config: do not include proxy.h nor errors.h anymore in cfgparse.h
4972 - BUILD: makefile: reorder object files by build time
4973 - DOC: Fix a few grammar/spelling issues and casing of HAProxy
4974 - REGTESTS: run-regtests: match both "HAProxy" and "HA-Proxy" in the version
4975 - MINOR: version: report "HAProxy" not "HA-Proxy" in the version output
4976 - DOC: remove last occurrences of "HA-Proxy" syntax
4977 - DOC: peers: fix the protocol tag name in the doc
4978 - ADMIN: netsnmp: report "HAProxy" and not "Haproxy" in output descriptions
4979 - MEDIUM: mailers: use "HAProxy" nor "HAproxy" in the subject of messages
4980 - DOC: fix a few remainig cases of "Haproxy" and "HAproxy" in doc and comments
4981 - MINOR: tools/rnd: compute the result outside of the CAS loop
4982 - BUILD: http_fetch: address a few aliasing warnings with older compilers
4983 - BUILD: ssl: define HAVE_CRYPTO_memcmp() based on the library version
4984 - BUILD: errors: include stdarg in errors.h
4985 - REGTESTS: disable inter-thread idle connection sharing on sensitive tests
4986 - MINOR: cli: make "help" support a command in argument
4987 - MINOR: cli: sort the output of the "help" keywords
4988 - CLEANUP: cli/mworker: properly align the help messages
4989 - BUILD: memprof: make the old caller pointer a const in get_prof_bin()
4990 - BUILD: compat: include malloc_np.h for USE_MEMORY_PROFILING on FreeBSD
4991 - CI: Github Actions: enable USE_QUIC=1 for BoringSSL builds
4992 - BUG/MEDIUM: quic: fix null deref on error path in qc_conn_init()
4993 - BUILD: cli: appease a null-deref warning in cli_gen_usage_msg()
4994
Willy Tarreau080347f2021-05-01 08:25:15 +020049952021/05/01 : 2.4-dev18
4996 - DOC: Fix indentation for `path-strip-dot` normalizer
4997 - DOC: Fix RFC reference for the percent-to-uppercase normalizer
4998 - DOC: Add RFC references for the path-strip-dot(dot)? normalizers
4999 - MINOR: uri_normalizer: Add a `percent-decode-unreserved` normalizer
5000 - BUG/MINOR: mux-fcgi: Don't send normalized uri to FCGI application
5001 - REORG: htx: Inline htx functions to add HTX blocks in a message
5002 - CLEANUP: assorted typo fixes in the code and comments
5003 - DOC: general: fix white spaces for HTML converter
5004 - BUG/MINOR: ssl: ssl_sock_prepare_ssl_ctx does not return an error code
5005 - BUG/MINOR: cpuset: move include guard at the very beginning
5006 - BUG/MAJOR: fix build on musl with cpu_set_t support
5007 - BUG/MEDIUM: cpuset: fix build on MacOS
5008 - BUG/MINOR: htx: Preserve HTX flags when draining data from an HTX message
5009 - MEDIUM: htx: Refactor htx_xfer_blks() to not rely on hdrs_bytes field
5010 - CLEANUP: htx: Remove unsued hdrs_bytes field from the HTX start-line
5011 - BUG/MINOR: mux-h2: Don't encroach on the reserve when decoding headers
5012 - MEDIUM: http-ana: handle read error on server side if waiting for response
5013 - MINOR: htx: Limit length of headers name/value when a HTX message is dumped
5014 - BUG/MINOR: applet: Notify the other side if data were consumed by an applet
5015 - BUG/MINOR: hlua: Don't consume headers when starting an HTTP lua service
5016 - BUG/MEDIUM: mux-h2: Handle EOM flag when sending a DATA frame with zero-copy
5017 - CLEANUP: channel: No longer notify the producer in co_skip()/co_htx_skip()
5018 - DOC: general: fix example in set-timeout
5019 - CLEANUP: cfgparse: de-uglify early file error handling in readcfgfile()
5020 - MINOR: config: add a new "default-path" global directive
5021 - BUG/MEDIUM: peers: initialize resync timer to get an initial full resync
5022 - BUG/MEDIUM: peers: register last acked value as origin receiving a resync req
5023 - BUG/MEDIUM: peers: stop considering ack messages teaching a full resync
5024 - BUG/MEDIUM: peers: reset starting point if peers appears longly disconnected
5025 - BUG/MEDIUM: peers: reset commitupdate value in new conns
5026 - BUG/MEDIUM: peers: re-work updates lookup during the sync on the fly
5027 - BUG/MEDIUM: peers: reset tables stage flags stages on new conns
5028 - MINOR: peers: add informative flags about resync process for debugging
5029 - BUG/MEDIUM: time: fix updating of global_now upon clock drift
5030 - CLEANUP: freq_ctr: make arguments of freq_ctr_total() const
5031 - CLEANUP: hlua: rename hlua_appctx* appctx to luactx
5032 - MINOR: server: fix doc/trace on lb algo for dynamic server creation
5033 - REGTESTS: server: fix cli_add_server due to previous trace update
5034 - REGTESTS: add minimal CLI "add map" tests
5035 - DOC: management: move "set var" to the proper place
5036 - CLEANUP: map: slightly reorder the add map function
5037 - MINOR: map: get rid of map_add_key_value()
5038 - MINOR: map: show the current and next pattern version in "show map"
5039 - MINOR: map/acl: add the possibility to specify the version in "show map/acl"
5040 - MINOR: pattern: support purging arbitrary ranges of generations
5041 - MINOR: map/acl: add the possibility to specify the version in "clear map/acl"
5042 - MINOR: map/acl: add the "prepare map/acl" CLI command
5043 - MINOR: map/acl: add the "commit map/acl" CLI command
5044 - MINOR: map/acl: make "add map/acl" support an optional version number
5045 - CLEANUP: map/cli: properly align the map/acl help
5046 - BUILD: compiler: do not use already defined __read_mostly on dragonfly
5047
Willy Tarreaubfd19d62021-04-23 19:11:10 +020050482021/04/23 : 2.4-dev17
5049 - MINOIR: mux-pt/trace: Register a new trace source with its events
5050 - BUG/MINOR: mux-pt: Fix a possible UAF because of traces in mux_pt_io_cb
5051 - CI: travis: Drastically clean up .travis.yml
5052 - CLEANUP: pattern: make all pattern tables read-only
5053 - MINOR: trace: replace the trace() inline function with an equivalent macro
5054 - MINOR: initcall: uniformize the section names between MacOS and other unixes
5055 - CLEANUP: initcall: rename HA_SECTION to HA_INIT_SECTION
5056 - MINOR: compiler: add macros to declare section names
5057 - CLEANUP: initcall: rely on HA_SECTION_* instead of defining its own
5058 - MINOR: global: declare a read_mostly section
5059 - MINOR: fd: move a few read-mostly variables to their own section
5060 - MINOR: epoll: move epoll_fd to read_mostly
5061 - MINOR: kqueue: move kqueue_fd to read_mostly
5062 - MINOR: pool: move pool declarations to read_mostly
5063 - MINOR: threads: mark all_threads_mask as read_mostly
5064 - MINOR: server: move idle_conn_task to read_mostly
5065 - MINOR: protocol: move __protocol_by_family to read_mostly
5066 - MINOR: pattern: make the pat_lru_seed read_mostly
5067 - MINOR: trace: make trace sources read_mostly
5068 - MINOR: freq_ctr: add a generic function to report the total value
5069 - MEDIUM: freq_ctr: make read_freq_ctr_period() use freq_ctr_total()
5070 - MEDIUM: freq_ctr: reimplement freq_ctr_remain_period() from freq_ctr_total()
5071 - MINOR: freq_ctr: add the missing next_event_delay_period()
5072 - MINOR: freq_ctr: unify freq_ctr and freq_ctr_period into freq_ctr
5073 - MEDIUM: freq_ctr: replace the per-second counters with the generic ones
5074 - MINOR: freq_ctr: add cpu_relax in the rotation loop of update_freq_ctr_period()
5075 - MINOR: freq_ctr: simplify and improve the update function
5076 - CLEANUP: time: remove the now unused ms_left_scaled
5077 - MINOR: time: move the time initialization out of tv_update_date()
5078 - MINOR: time: remove useless variable copies in tv_update_date()
5079 - MINOR: time: change the global timeval and the the global tick at once
5080 - MEDIUM: time: make the clock offset global and no per-thread
5081 - MINOR: atomic: reimplement the relaxed version of x86 BTS/BTR
5082 - MINOR: trace: Add the checks as a possible trace source
5083 - MINOIR: checks/trace: Register a new trace source with its events
5084 - MINOR: hlua: Add function to release a lua function
5085 - BUG/MINOR: hlua: Fix memory leaks on error path when registering a task
5086 - BUG/MINOR: hlua: Fix memory leaks on error path when registering a converter
5087 - BUG/MINOR: hlua: Fix memory leaks on error path when registering a fetch
5088 - BUG/MINOR: hlua: Fix memory leaks on error path when parsing a lua action
5089 - BUG/MINOR: hlua: Fix memory leaks on error path when registering an action
5090 - BUG/MINOR: hlua: Fix memory leaks on error path when registering a service
5091 - BUG/MINOR: hlua: Fix memory leaks on error path when registering a cli keyword
5092 - BUG/MINOR: cfgparse/proxy: Fix some leaks during proxy section parsing
5093 - BUG/MINOR: listener: Handle allocation error when allocating a new bind_conf
5094 - BUG/MINOR: cfgparse/proxy: Hande allocation errors during proxy section parsing
5095 - MINOR: cfgparse/proxy: Group alloc error handling during proxy section parsing
5096 - DOC: internals: update the SSL architecture schema
5097 - BUG/MEDIUM: sample: Fix adjusting size in field converter
5098 - MINOR: sample: add ub64dec and ub64enc converters
5099 - CLEANUP: sample: align samples list in sample.c
5100 - MINOR: ist: Add `istclear(struct ist*)`
5101 - CI: cirrus: install "pcre" package
5102 - MINOR: opentracing: correct calculation of the number of arguments in the args[]
5103 - MINOR: opentracing: transfer of context names without prefix
5104 - MINOR: sample: converter: Add mjson library.
5105 - MINOR: sample: converter: Add json_query converter
5106 - CI: travis-ci: enable weekly graviton2 builds
5107 - DOC: ssl: Certificate hot update only works on fronted certificates
5108 - DOC: ssl: Certificate hot update works on server certificates
5109 - BUG/MEDIUM: threads: Ignore current thread to end its harmless period
5110 - MINOR: threads: Only consider running threads to end a thread harmeless period
5111 - BUG/MINOR: checks: Set missing id to the dummy checks frontend
5112 - MINOR: logs: Add support of checks as session origin to format lf strings
5113 - BUG/MINOR: connection: Fix fc_http_major and bc_http_major for TCP connections
5114 - MINOR: connection: Make bc_http_major compatible with tcp-checks
5115 - BUG/MINOR: ssl-samples: Fix ssl_bc_* samples when called from a health-check
5116 - BUG/MINOR: http-fetch: Make method smp safe if headers were already forwarded
5117 - MINOR: tcp_samples: Add samples to get src/dst info of the backend connection
5118 - MINOR: tcp_samples: Be able to call bc_src/bc_dst from the health-checks
5119 - BUG/MINOR: http_htx: Remove BUG_ON() from http_get_stline() function
5120 - BUG/MINOR: logs: Report the true number of retries if there was no connection
5121 - BUILD: makefile: Redirect stderr to /dev/null when probing options
5122 - MINOR: uri_normalizer: Add uri_normalizer module
5123 - MINOR: uri_normalizer: Add `enum uri_normalizer_err`
5124 - MINOR: uri_normalizer: Add `http-request normalize-uri`
5125 - MINOR: uri_normalizer: Add a `merge-slashes` normalizer to http-request normalize-uri
5126 - MINOR: uri_normalizer: Add a `dotdot` normalizer to http-request normalize-uri
5127 - MINOR: uri_normalizer: Add support for supressing leading `../` for dotdot normalizer
5128 - MINOR: uri_normalizer: Add a `sort-query` normalizer
5129 - MINOR: uri_normalizer: Add a `percent-upper` normalizer
5130 - MEDIUM: http_act: Rename uri-normalizers
5131 - DOC: Add introduction to http-request normalize-uri
5132 - DOC: Note that URI normalization is experimental
5133 - BUG/MINOR: pools: maintain consistent ->allocated count on alloc failures
5134 - BUG/MINOR: pools/buffers: make sure to always reserve the required buffers
5135 - MINOR: pools: drop the unused static history of artificially failed allocs
5136 - CLEANUP: pools: remove unused arguments to pool_evict_from_cache()
5137 - MEDIUM: pools: move the cache into the pool header
5138 - MINOR: pool: remove the size field from pool_cache_head
5139 - MINOR: pools: rename CONFIG_HAP_LOCAL_POOLS to CONFIG_HAP_POOLS
5140 - MINOR: pools: enable the fault injector in all allocation modes
5141 - MINOR: pools: make the basic pool_refill_alloc()/pool_free() update needed_avg
5142 - MEDIUM: pools: unify pool_refill_alloc() across all models
5143 - CLEANUP: pools: re-merge pool_refill_alloc() and __pool_refill_alloc()
5144 - MINOR: pools: call pool_alloc_nocache() out of the pool's lock
5145 - CLEANUP: pools: move the lock to the only __pool_get_first() that needs it
5146 - CLEANUP: pools: rename __pool_get_first() to pool_get_from_shared_cache()
5147 - CLEANUP: pools: rename pool_*_{from,to}_cache() to *_local_cache()
5148 - CLEANUP: pools: rename __pool_free() to pool_put_to_shared_cache()
5149 - MINOR: tools: add statistical_prng_range() to get a random number over a range
5150 - MINOR: pools: use cheaper randoms for fault injections
5151 - MINOR: pools: move the fault injector to __pool_alloc()
5152 - MINOR: pools: split the OS-based allocator in two
5153 - MINOR: pools: always use atomic ops to maintain counters
5154 - MINOR: pools: move pool_free_area() out of the lock in the locked version
5155 - MINOR: pools: factor the release code into pool_put_to_os()
5156 - MEDIUM: pools: make CONFIG_HAP_POOLS control both local and shared pools
5157 - MINOR: pools: create unified pool_{get_from,put_to}_cache()
5158 - MINOR: pools: evict excess objects using pool_evict_from_local_cache()
5159 - MEDIUM: pools: make pool_put_to_cache() always call pool_put_to_local_cache()
5160 - CLEANUP: pools: make the local cache allocator fall back to the shared cache
5161 - CLEANUP: pools: merge pool_{get_from,put_to}_local_caches with generic ones
5162 - CLEANUP: pools: uninline pool_put_to_cache()
5163 - CLEANUP: pools: declare dummy pool functions to remove some ifdefs
5164 - BUILD: pools: fix build with DEBUG_FAIL_ALLOC
5165 - BUG/MINOR: server: make srv_alloc_lb() allocate lb_nodes for consistent hash
5166 - CONTRIB: mod_defender: import the minimal number of includes
5167 - CONTRIB: mod_defender: make the code build with the embedded includes
5168 - CONTRIB: modsecurity: import the minimal number of includes
5169 - CONTRIB: modsecurity: make the code build with the embedded includes
5170 - CLEANUP: sample: Improve local variables in sample_conv_json_query
5171 - CLEANUP: sample: Explicitly handle all possible enum values from mjson
5172 - CLEANUP: sample: Use explicit return for successful `json_query`s
5173 - CLEANUP: lists/tree-wide: rename some list operations to avoid some confusion
5174 - CONTRIB: move spoa_example out of the tree
5175 - BUG/MINOR: server: free srv.lb_nodes in free_server
5176 - BUG/MINOR: logs: free logsrv.conf.file on exit
5177 - BUG/MEDIUM: server: ensure thread-safety of server runtime creation
5178 - MINOR: server: add log on dynamic server creation
5179 - MINOR: server: implement delete server cli command
5180 - CONTRIB: move spoa_server out of the tree
5181 - CONTRIB: move modsecurity out of the tree
5182 - BUG/MINOR: server: fix potential null gcc error in delete server
5183 - BUG/MAJOR: mux-h2: Properly detect too large frames when decoding headers
5184 - BUG/MEDIUM: mux-h2: Fix dfl calculation when merging CONTINUATION frames
5185 - BUG/MINOR: uri_normalizer: Use delim parameter when building the sorted query in uri_normalizer_query_sort
5186 - CLEANUP: uri_normalizer: Remove trailing whitespace
5187 - MINOR: uri_normalizer: Add a `strip-dot` normalizer
5188 - CONTRIB: move mod_defender out of the tree
5189 - CLEANUP: contrib: remove the last references to the now dead contrib/ directory
5190 - BUG/MEDIUM: config: fix cpu-map notation with both process and threads
5191 - MINOR: config: add a diag for invalid cpu-map statement
5192 - BUG/MINOR: mworker/init: don't reset nb_oldpids in non-mworker cases
5193 - BUG/MINOR: mworker: don't use oldpids[] anymore for reload
5194 - BUILD: makefile: fix the "make clean" target on strict bourne shells
5195 - IMPORT: slz: import slz into the tree
5196 - BUILD: compression: switch SLZ from out-of-tree to in-tree
5197 - CI: github: do not build libslz any more
5198 - CLEANUP: compression: remove calls to SLZ init functions
5199 - BUG/MEDIUM: mux-h2: Properly handle shutdowns when received with data
5200 - MINOR: cpuset: define a platform-independent cpuset type
5201 - MINOR: cfgparse: use hap_cpuset for parse_cpu_set
5202 - MEDIUM: config: use platform independent type hap_cpuset for cpu-map
5203 - MINOR: thread: implement the detection of forced cpu affinity
5204 - MINOR: cfgparse: support the comma separator on parse_cpu_set
5205 - MEDIUM: cfgparse: detect numa and set affinity if needed
5206 - MINOR: global: add option to disable numa detection
5207 - BUG/MINOR: haproxy: fix compilation on macOS
5208 - BUG/MINOR: cpuset: fix compilation on platform without cpu affinity
5209 - MINOR: time: avoid unneeded updates to now_offset
5210 - MINOR: time: avoid overwriting the same values of global_now
5211 - CLEANUP: time: use __tv_to_ms() in tv_update_date() instead of open-coding
5212 - MINOR: time: avoid u64 needlessly expensive computations for the 32-bit now_ms
5213 - BUG/MINOR: peers: remove useless table check if initial resync is finished
5214 - BUG/MEDIUM: peers: re-work connection to new process during reload.
5215 - BUG/MEDIUM: peers: re-work refcnt on table to protect against flush
5216 - BUG/MEDIUM: config: fix missing initialization in numa_detect_topology()
5217
Willy Tarreau86512dd2021-04-09 17:10:39 +020052182021/04/09 : 2.4-dev16
5219 - CLEANUP: dev/flags: remove useless test in the stdin number parser
5220 - MINOR: No longer rely on deprecated sample fetches for predefined ACLs
5221 - MINOR: acl: Add HTTP_2.0 predefined macro
5222 - BUG/MINOR: hlua: Detect end of request when reading data for an HTTP applet
5223 - BUG/MINOR: tools: fix parsing "us" unit for timers
5224 - MINOR: server/bind: add support of new prefixes for addresses.
5225 - MINOR: log: register config file and line number on log servers.
5226 - MEDIUM: log: support tcp or stream addresses on log lines.
5227 - BUG/MEDIUM: log: fix config parse error logging on stdout/stderr or any raw fd
5228 - CLEANUP: fd: remove FD_POLL_DATA and FD_POLL_STICKY
5229 - MEDIUM: fd: prepare FD_POLL_* to move to bits 8-15
5230 - MEDIUM: fd: merge fdtab[].ev and state for FD_EV_* and FD_POLL_* into state
5231 - MINOR: fd: move .linger_risk into fdtab[].state
5232 - MINOR: fd: move .cloned into fdtab[].state
5233 - MINOR: fd: move .initialized into fdtab[].state
5234 - MINOR: fd: move .et_possible into fdtab[].state
5235 - MINOR: fd: move .exported into fdtab[].state
5236 - MINOR: fd: implement an exclusive syscall bit to remove the ugly "log" lock
5237 - MINOR: cli/show-fd: slightly reorganize the FD status flags
5238 - MINOR: atomic/arm64: detect and use builtins for the double-word CAS
5239 - CLEANUP: atomic: add an explicit _FETCH variant for add/sub/and/or
5240 - CLEANUP: atomic: make all standard add/or/and/sub operations return void
5241 - CLEANUP: atomic: add a fetch-and-xxx variant for common operations
5242 - CLEANUP: atomic: add HA_ATOMIC_INC/DEC for unit increments
5243 - CLEANUP: atomic/tree-wide: replace single increments/decrements with inc/dec
5244 - CLEANUP: atomic: use the __atomic variant of BTS/BTR on modern compilers
5245 - MINOR: atomic: implement native BTS/BTR for x86
5246 - MINOR: ist: Add `istappend(struct ist, char)`
5247 - MINOR: ist: Add `istshift(struct ist*)`
5248 - MINOR: ist: Add `istsplit(struct ist*, char)`
5249 - BUG/MAJOR: fd: switch temp values to uint in fd_stop_both()
5250 - MINOR: opentracing: register config file and line number on log servers
5251 - MEDIUM: resolvers: add support of tcp address on nameserver line.
5252 - MINOR: ist: Rename istappend() to __istappend()
5253 - CLEANUP: htx: Make http_get_stline take a `const struct`
5254 - CLEANUP: ist: Remove unused `count` argument from `ist2str*`
5255 - CLEANUP: Remove useless malloc() casts
5256
Willy Tarreau59fa1d12021-04-02 19:16:32 +020052572021/04/02 : 2.4-dev15
5258 - BUG/MINOR: payload: Wait for more data if buffer is empty in payload/payload_lv
5259 - BUG/MINOR: stats: Apply proper styles in HTML status page.
5260 - BUG/MEDIUM: time: make sure to always initialize the global tick
5261 - BUG/MINOR: tcp: fix silent-drop workaround for IPv6
5262 - BUILD: tcp: use IPPROTO_IPV6 instead of SOL_IPV6 on FreeBSD/MacOS
5263 - CLEANUP: socket: replace SOL_IP/IPV6/TCP with IPPROTO_IP/IPV6/TCP
5264 - BUG/MINOR: http_fetch: make hdr_ip() resistant to empty fields
5265 - BUG/MINOR: mux-h2: Don't emit log twice if an error occurred on the preface
5266 - MINOR: stream: Don't trigger errors on destructive HTTP upgrades
5267 - MINOR: frontend: Create HTTP txn for HTX streams
5268 - MINOR: stream: Be sure to set HTTP analysers when creating an HTX stream
5269 - BUG/MINOR: stream: Properly handle TCP>H1>H2 upgrades in http_wait_for_request
5270 - BUG/MINOR: config: Add warning for http-after-response rules in TCP mode
5271 - MINOR: muxes: Add a flag to notify a mux does not support any upgrade
5272 - MINOR: mux-h1: Don't perform implicit HTTP/2 upgrade if not supported by mux
5273 - MINOR: mux-pt: Don't perform implicit HTTP upgrade if not supported by mux
5274 - MEDIUM: mux-h1: Expose h1 in the list of supported mux protocols
5275 - MEDIUM: mux-pt: Expose passthrough in the list of supported mux protocols
5276 - MINOR: muxes: Show muxes flags when the mux list is displayed
5277 - DOC: config: Improve documentation about proto/check-proto keywords
5278 - MINOR: stream: Use stream type instead of proxy mode when appropriate
5279 - MINOR: filters/http-ana: Decide to filter HTTP headers in HTTP analysers
5280 - MINOR: http-ana: Simplify creation/destruction of HTTP transactions
5281 - MINOR: stream: Handle stream HTTP upgrade in a dedicated function
5282 - MEDIUM: Add tcp-request switch-mode action to perform HTTP upgrade
5283 - MINOR: config/proxy: Don't warn for HTTP rules in TCP if 'switch-mode http' set
5284 - MINOR: config/proxy: Warn if a TCP proxy without backend is upgradable to HTTP
5285 - DOC: config: Add documentation about TCP to HTTP upgrades
5286 - REGTESTS: Add script to tests TCP to HTTP upgrades
5287 - BUG/MINOR: payload/htx: Ingore L6 sample fetches for HTX streams/checks
5288 - MINOR: htx: Make internal.strm.is_htx an internal sample fetch
5289 - MINOR: action: Use a generic function to check validity of an action rule list
5290 - MINOR: payload/config: Warn if a L6 sample fetch is used from an HTTP proxy
5291 - MEDIUM: http-rules: Add wait-for-body action on request and response side
5292 - REGTESTS: Add script to tests the wait-for-body HTTP action
5293 - BUG/MINOR: http-fetch: Fix test on message state to capture the version
5294 - CLEANUP: vars: always pre-initialize smp in vars_parse_cli_get_var()
5295 - MINOR: global: define diagnostic mode of execution
5296 - MINOR: cfgparse: diag for multiple nbthread statements
5297 - MINOR: server: diag for 0 weight server
5298 - MINOR: diag: create cfgdiag module
5299 - MINOR: diag: diag if servers use the same cookie value
5300 - MINOR: config: diag if global section after non-global
5301 - TESTS: slightly reorganize the code in the tests/ directory
5302 - TESTS: move tests/*.cfg to tests/config
5303 - REGTESTS: ssl: "set ssl cert" and multi-certificates bundle
5304 - REGTESTS: ssl: mark set_ssl_cert_bundle.vtc as broken
5305 - CONTRIB: halog: fix issue with array of type char
5306 - CONTRIB: tcploop: add a shutr command
5307 - CONTRIB: debug: add the show-fd-to-flags script
5308 - CONTRIB: debug: split poll from flags
5309 - CONTRIB: move some dev-specific tools to dev/
5310 - BUILD: makefile: always build the flags utility
5311 - DEV: flags: replace the unneeded makefile with a README
5312 - BUILD: makefile: integrate the hpack tools
5313 - CONTRIB: merge ip6range with iprange
5314 - CONTRIB: move some admin-related sub-projects to admin/
5315 - CONTRIB: move halog to admin/
5316 - ADMIN: halog: automatically enable USE_MEMCHR on the right glibc version
5317 - BUILD: makefile: build halog with the correct flags
5318 - BUILD: makefile: add a "USE_PROMEX" variable to ease building prometheus-exporter
5319 - CONTRIB: move prometheus-exporter to addons/promex
5320 - DOC: add a few words about USE_* and the addons directory
5321 - CONTRIB: move 51Degrees to addons/51degrees
5322 - CONTRIB: move src/da.c and contrib/deviceatlas to addons/deviceatlas
5323 - CONTRIB: move src/wurfl.c and contrib/wurfl to addons/wurfl
5324 - CONTRIB: move contrib/opentracing to addons/ot
5325 - BUG/MINOR: opentracing: initialization after establishing daemon mode
5326 - DOC: clarify that compression works for HTTP/2
5327
Willy Tarreauaf6d88b2021-03-27 09:42:09 +010053282021/03/27 : 2.4-dev14
5329 - MEDIUM: quic: Fix build.
5330 - MEDIUM: quic: Fix build.
5331 - CI: codespell: whitelist "Dragan Dosen"
5332 - CLEANUP: assorted typo fixes in the code and comments
5333 - CI: github actions: update LibreSSL to 3.2.5
5334 - REGTESTS: revert workaround for a crash with recent libressl on http-reuse sni
5335 - CLEANUP: mark defproxy as const on parse tune.fail-alloc
5336 - REGTESTS: remove unneeded experimental-mode in cli add server test
5337 - REGTESTS: wait for proper return of enable server in cli add server test
5338 - MINOR: compression: use pool_alloc(), not pool_alloc_dirty()
5339 - MINOR: spoe: use pool_alloc(), not pool_alloc_dirty()
5340 - MINOR: fcgi-app: use pool_alloc(), not pool_alloc_dirty()
5341 - MINOR: cache: use pool_alloc(), not pool_alloc_dirty()
5342 - MINOR: ssl: use pool_alloc(), not pool_alloc_dirty()
5343 - MINOR: opentracing: use pool_alloc(), not pool_alloc_dirty()
5344 - MINOR: dynbuf: make b_alloc() always check if the buffer is allocated
5345 - CLEANUP: compression: do not test for buffer before calling b_alloc()
5346 - CLEANUP: l7-retries: do not test the buffer before calling b_alloc()
5347 - MINOR: channel: simplify the channel's buffer allocation
5348 - MEDIUM: dynbuf: remove last usages of b_alloc_margin()
5349 - CLEANUP: dynbuf: remove b_alloc_margin()
5350 - CLEANUP: dynbuf: remove the unused b_alloc_fast() function
5351 - CLEANUP: pools: remove the unused pool_get_first() function
5352 - MINOR: pools: make the pool allocator support a few flags
5353 - MINOR: pools: add pool_zalloc() to return a zeroed area
5354 - CLEANUP: connection: use pool_zalloc() in conn_alloc_hash_node()
5355 - CLEANUP: filters: use pool_zalloc() in flt_stream_add_filter()
5356 - CLEANUP: spoe: use pool_zalloc() instead of pool_alloc+memset
5357 - CLEANUP: frontend: use pool_zalloc() in frontend_accept()
5358 - CLEANUP: mailers: use pool_zalloc() in enqueue_one_email_alert()
5359 - CLEANUP: resolvers: use pool_zalloc() in resolv_link_resolution()
5360 - CLEANUP: ssl: use pool_zalloc() in ssl_init_keylog()
5361 - CLEANUP: tcpcheck: use pool_zalloc() instead of pool_alloc+memset
5362 - CLEANUP: quic: use pool_zalloc() instead of pool_alloc+memset
5363 - MINOR: time: also provide a global, monotonic global_now_ms timer
5364 - BUG/MEDIUM: freq_ctr/threads: use the global_now_ms variable
5365 - MINOR: tools: introduce new option PA_O_DEFAULT_DGRAM on str2sa_range.
5366 - BUILD: tools: fix build error with new PA_O_DEFAULT_DGRAM
5367 - BUG/MINOR: ssl: Prevent disk access when using "add ssl crt-list"
5368 - CLEANUP: ssl: remove unused definitions
5369 - BUILD: ssl: guard ecdh functions with SSL_CTX_set_tmp_ecdh macro
5370 - MINOR: lua: Slightly improve function dumping the lua traceback
5371 - BUG/MEDIUM: debug/lua: Use internal hlua function to dump the lua traceback
5372 - BUG/MEDIUM: lua: Always init the lua stack before referencing the context
5373 - MINOR: fd: make fd_clr_running() return the remaining running mask
5374 - MINOR: fd: remove the unneeded running bit from fd_insert()
5375 - BUG/MEDIUM: fd: do not wait on FD removal in fd_delete()
5376 - CLEANUP: fd: remove unused fd_set_running_excl()
5377 - CLEANUP: fd: slightly simplify up _fd_delete_orphan()
5378 - BUG/MEDIUM: fd: Take the fd_mig_lock when closing if no DWCAS is available.
5379 - BUG/MEDIUM: release lock on idle conn killing on reached pool high count
5380 - BUG/MEDIUM: thread: Fix a deadlock if an isolated thread is marked as harmless
5381 - MINOR: tools: make url2ipv4 return the exact number of bytes parsed
5382 - BUG/MINOR: http_fetch: make hdr_ip() reject trailing characters
5383 - BUG/MEDIUM: mux-h1: make h1_shutw_conn() idempotent
5384 - BUG/MINOR: ssl: Fix update of default certificate
5385 - BUG/MINOR: ssl: Prevent removal of crt-list line if the instance is a default one
5386 - BUILD: ssl: introduce fine guard for ssl random extraction functions
5387 - REORG: global: move initcall register code in a dedicated file
5388 - REORG: global: move free acl/action in their related source files
5389 - REORG: split proxy allocation functions
5390 - MINOR: proxy: implement a free_proxy function
5391 - MINOR: proxy: define cap PR_CAP_LUA
5392 - MINOR: lua: properly allocate the lua Socket proxy
5393 - MINOR: lua: properly allocate the lua Socket servers
5394 - MINOR: vars: make get_vars() allow the session to be null
5395 - MINOR: vars: make the var() sample fetch keyword depend on nothing
5396 - CLEANUP: sample: remove duplicate "stopping" sample fetch keyword
5397 - MINOR: sample: make smp_resolve_args() return an allocate error message
5398 - MINOR: sample: add a new SMP_SRC_CONST sample capability
5399 - MINOR: sample: mark the truly constant sample fetch keywords as such
5400 - MINOR: sample: add a new CFG_PARSER context for samples
5401 - MINOR: action: add a new ACT_F_CFG_PARSER origin designation
5402 - MEDIUM: vars: add support for a "set-var" global directive
5403 - REGTESTS: add a basic reg-test for some "set-var" commands
5404 - MINOR: sample: add a new CLI_PARSER context for samples
5405 - MINOR: action: add a new ACT_F_CLI_PARSER origin designation
5406 - MINOR: vars/cli: add a "get var" CLI command to retrieve global variables
5407 - MEDIUM: cli: add a new experimental "set var" command
5408 - MINOR: compat: add short aliases for a few very commonly used types
5409 - BUILD: ssl: use EVP_CIPH_GCM_MODE macro instead of HA_OPENSSL_VERSION
5410 - MEDIUM: backend: use a trylock to grab a connection on high FD counts as well
5411
Willy Tarreau09cc6692021-03-19 17:16:18 +010054122021/03/19 : 2.4-dev13
5413 - BUG/MEDIUM: cli: fix "help" crashing since recent spelling fixes
5414 - BUG/MINOR: cfgparse: use the GLOBAL not LISTEN keywords list for spell checking
5415 - MINOR: tools: improve word fingerprinting by counting presence
5416 - MINOR: tools: do not sum squares of differences for word fingerprints
5417 - MINOR: cli: improve fuzzy matching to work on all remaining words at once
5418 - MINOR: cli: sort the suggestions by order of relevance
5419 - MINOR: cli: limit spelling suggestions to 5
5420 - MINOR: cfgparse/proxy: also support spelling fixes on options
5421 - BUG/MINOR: resolvers: Add missing case-insensitive comparisons of DNS hostnames
5422 - MINOR: time: export the global_now variable
5423 - BUG/MINOR: freq_ctr/threads: make use of the last updated global time
5424 - MINOR: freq_ctr/threads: relax when failing to update a sliding window value
5425 - MINOR/BUG: mworker/cli: do not use the unix_bind prefix for the master CLI socket
5426 - MINOR: mworker/cli: alert the user if we enabled a master CLI but not the master-worker mode
5427 - MINOR: cli: implement experimental-mode
5428 - REORG: server: add a free server function
5429 - MINOR: cfgparse: always alloc idle conns task
5430 - REORG: server: move keywords in srv_kws
5431 - MINOR: server: remove fastinter from mistyped kw list
5432 - REORG: server: split parse_server
5433 - REORG: server: move alert traces in parse_server
5434 - REORG: server: rename internal functions from parse_server
5435 - REORG: server: attach servers in parse_server
5436 - REORG: server: use flags for parse_server
5437 - MINOR: server: prepare parsing for dynamic servers
5438 - MINOR: stats: export function to allocate extra proxy counters
5439 - MEDIUM: server: implement 'add server' cli command
5440 - REGTESTS: implement test for 'add server' cli
5441 - MINOR: server: enable standard options for dynamic servers
5442 - MINOR: server: support keyword proto in 'add server' cli
5443 - BUG/MINOR: protocol: add missing support of dgram unix socket.
5444 - CLEANUP: Fix a typo in fix_is_valid description
5445 - MINOR: raw_sock: Add a close method.
5446 - MEDIUM: connections: Introduce a new XPRT method, start().
5447 - MEDIUM: connections: Implement a start() method for xprt_handshake.
5448 - MEDIUM: connections: Implement a start() method in ssl_sock.
5449 - MINOR: muxes: garbage collect the reset() method.
5450 - CLEANUP: tcp-rules: Fix a typo in error messages about expect-netscaler-cip
5451 - MEDIUM: lua: Use a per-thread counter to track some non-reentrant parts of lua
5452 - BUG/MEDIUM: debug/lua: Don't dump the lua stack if not dumpable
5453
Willy Tarreauacdd47d2021-03-13 11:48:28 +010054542021/03/13 : 2.4-dev12
5455 - CLEANUP: connection: Use `VAR_ARRAY` in `struct tlv` definition
5456 - CLEANUP: connection: Remove useless test for NULL before calling `pool_free()`
5457 - CLEANUP: connection: Use istptr / istlen for proxy_unique_id
5458 - MINOR: connection: Use a `struct ist` to store proxy_authority
5459 - CLEANUP: connection: Consistently use `struct ist` to process all TLV types
5460 - BUILD: task: fix build at -O0 with threads disabled
5461 - BUILD: bug: refine HA_LINK_ERROR() to only be used on gcc and derivatives
5462 - CLEANUP: config: make the cfg_keyword parsers take a const for the defproxy
5463 - BUILD: connection: do not use VAR_ARRAY in struct tlv
5464 - BUG/MEDIUM: session: NULL dereference possible when accessing the listener
5465 - MINOR: build: force CC to set a return code when probing options
5466 - CLEANUP: stream: rename a few remaining occurrences of "stream *sess"
5467 - BUG/MEDIUM: resolvers: handle huge responses over tcp servers.
5468 - CLEANUP: config: also address the cfg_keyword API change in the compression code
5469 - BUG/MEDIUM: ssl: properly remove the TASK_HEAVY flag at end of handshake
5470 - BUG/MINOR: sample: Rename SenderComID/TargetComID to SenderCompID/TargetCompID
5471 - MINOR: task: give the scheduler a bit more flexibility in the runqueue size
5472 - OPTIM: task: automatically adjust the default runqueue-depth to the threads
5473 - BUG/MINOR: connection: Missing QUIC initialization
5474 - BUG/MEDIUM: stick-tables: fix ref counter in table entry using multiple http tracksc.
5475 - BUILD: atomic/arm64: force the register pairs to use in __ha_cas_dw()
5476 - BUG/MEDIUM: filters: Set CF_FL_ANALYZE on channels when filters are attached
5477 - BUG/MINOR: tcpcheck: Update .health threshold of agent inside an agent-check
5478 - BUG/MINOR: proxy/session: Be sure to have a listener to increment its counters
5479 - BUG/MINOR: tcpcheck: Fix double free on error path when parsing tcp/http-check
5480 - BUG/MINOR: server-state: properly handle the case where the base is not set
5481 - BUG/MINOR: server-state: use the argument, not the global state
5482 - CLEANUP: tcp-rules: add missing actions in the tcp-request error message
5483 - CLEANUP: vars: make the error message clearer on missing arguments for set-var
5484 - CLEANUP: http-rules: remove the unexpected comma before the list of action keywords
5485 - CLEANUP: actions: the keyword must always be const from the rule
5486 - MINOR: tools: add simple word fingerprinting to find similar-looking words
5487 - MINOR: cfgparse: add cfg_find_best_match() to suggest an existing word
5488 - MINOR: cfgparse: suggest correct spelling for unknown words in proxy sections
5489 - MINOR: cfgparse: suggest correct spelling for unknown words in global section
5490 - MINOR: cfgparse/server: try to fix spelling mistakes on server lines
5491 - MINOR: cfgparse/bind: suggest correct spelling for unknown bind keywords
5492 - MINOR: actions: add a function to suggest an action ressembling a given word
5493 - MINOR: http-rules: suggest approaching action names on mismatch
5494 - MINOR: tcp-rules: suggest approaching action names on mismatch
5495 - BUG/MINOR: cfgparse/server: increment the extra keyword counter one at a time
5496 - Revert "BUG/MINOR: resolvers: Only renew TTL for SRV records with an additional record"
5497 - BUG/MINOR: resolvers: Consider server to have no IP on DNS resolution error
5498 - BUG/MINOR: resolvers: Reset server address on DNS error only on status change
5499 - BUG/MINOR: resolvers: Unlink DNS resolution to set RMAINT on SRV resolution
5500 - BUG/MEDIUM: resolvers: Don't set an address-less server as UP
5501 - BUG/MEDIUM: resolvers: Fix the loop looking for an existing ADD item
5502 - MINOR: resolvers: new function find_srvrq_answer_record()
5503 - BUG/MINOR; resolvers: Ignore DNS resolution for expired SRV item
5504 - BUG/MEDIUM: resolvers: Trigger a DNS resolution if an ADD item is obsolete
5505 - MINOR: resolvers: Use a function to remove answers attached to a resolution
5506 - MINOR: resolvers: Purge answer items when a SRV resolution triggers an error
5507 - MINOR: resolvers: Add function to change the srv status based on SRV resolution
5508 - MINOR: resolvers: Directly call srvrq_update_srv_state() when possible
5509 - BUG/MEDIUM: resolvers: Don't release resolution from a requester callbacks
5510 - BUG/MEDIUM: resolvers: Skip DNS resolution at startup if SRV resolution is set
5511 - MINOR: resolvers: Use milliseconds for cached items in resolver responses
5512 - MINOR: resolvers: Don't try to match immediatly renewed ADD items
5513 - CLEANUP: resolvers: Use ha_free() in srvrq_resolution_error_cb()
5514 - CLEANUP: resolvers: Perform unsafe loop on requester list when possible
5515 - BUG/MINOR: cli: make sure "help", "prompt", "quit" are enabled at master level
5516 - CLEANUP: cli: fix misleading comment and better indent the access level flags
5517 - MINOR: cli: set the ACCESS_MASTER* bits on the master bind_conf
5518 - MINOR: cli: test the appctx level for master access instead of comparing pointers
5519 - MINOR: cli: print the error message in the parser function itself
5520 - MINOR: cli: filter the list of commands to the matching part
5521 - MEDIUM: cli: apply spelling fixes for known commands before listing them
5522 - MINOR: tools: add the ability to update a word fingerprint
5523 - MINOR: cli: apply the fuzzy matching on the whole command instead of words
5524 - CLEANUP: cli: rename MAX_STATS_ARGS to MAX_CLI_ARGS
5525 - CLEANUP: cli: rename the last few "stats_" to "cli_"
5526 - CLEANUP: task: make sure tasklet handlers always indicate their statuses
5527 - CLEANUP: assorted typo fixes in the code and comments
5528
Willy Tarreau7bbc6c92021-03-05 21:24:23 +010055292021/03/05 : 2.4-dev11
5530 - CI: codespell: skip Makefile for spell check
5531 - CLEANUP: assorted typo fixes in the code and comments
5532 - BUG/MINOR: tcp-act: Don't forget to set the original port for IPv4 set-dst rule
5533 - BUG/MINOR: connection: Use the client's dst family for adressless servers
5534 - BUG/MEDIUM: spoe: Kill applets if there are pending connections and nbthread > 1
5535 - CLEANUP: Use ist2(const void*, size_t) whenever possible
5536 - CLEANUP: Use IST_NULL whenever possible
5537 - BUILD: proxy: Missing header inclusion for quic_transport_params_init()
5538 - BUILD: quic: Implicit conversion between SSL related enums.
5539 - DOC: spoe: Add a note about fragmentation support in HAProxy
5540 - MINOR: contrib: add support for heartbeat control messages.
5541 - MINOR: contrib: Enhance peers dissector heuristic.
5542 - BUG/MINOR: mux-h2: Fix typo in scheme adjustment
5543 - CLEANUP: Reapply the ist2() replacement patch
5544 - CLEANUP: Use istadv(const struct ist, const size_t) whenever possible
5545 - CLEANUP: Use isttest(const struct ist) whenever possible
5546 - Revert "CI: Pin VTest to a known good commit"
5547 - CLEANUP: backend: fix a wrong comment
5548 - BUG/MINOR: backend: free allocated bind_addr if reuse conn
5549 - MINOR: backend: handle reuse for conns with no server as target
5550 - REGTESTS: test http-reuse if no server target
5551 - BUG/MINOR: hlua: Don't strip last non-LWS char in hlua_pushstrippedstring()
5552 - BUG/MINOR: server-state: Don't load server-state file for disabled backends
5553 - CLEANUP: dns: Use DISGUISE() on a never-failing ring_attach() call
5554 - CLEANUP: dns: Remove useless test on ns->dgram in dns_connect_nameserver()
5555 - DOC: fix originalto except clause on destination address
5556 - CLEANUP: Use the ist() macro whenever possible
5557 - CLEANUP: Replace for loop with only a condition by while
5558 - REORG: atomic: reimplement pl_cpu_relax() from atomic-ops.h
5559 - BUG/MINOR: mt-list: always perform a cpu_relax call on failure
5560 - MINOR: atomic: add armv8.1-a atomics variant for cas-dw
5561 - MINOR: atomic: implement a more efficient arm64 __ha_cas_dw() using pairs
5562 - BUG/MINOR: ssl: don't truncate the file descriptor to 16 bits in debug mode
5563 - MEDIUM: pools: add CONFIG_HAP_NO_GLOBAL_POOLS and CONFIG_HAP_GLOBAL_POOLS
5564 - MINOR: pools: double the local pool cache size to 1 MB
5565 - MINOR: stream: use ABORT_NOW() and not abort() in stream_dump_and_crash()
5566 - CLEANUP: stream: explain why we queue the stream at the head of the server list
5567 - MEDIUM: backend: use a trylock when trying to grab an idle connection
5568 - REORG: tools: promote the debug PRNG to more general use as a statistical one
5569 - OPTIM: lb-random: use a cheaper PRNG to pick a server
5570 - MINOR: task: stop abusing the nice field to detect a tasklet
5571 - MINOR: task: move the nice field to the struct task only
5572 - MEDIUM: task: extend the state field to 32 bits
5573 - MINOR: task: add an application specific flag to the state: TASK_F_USR1
5574 - MEDIUM: muxes: mark idle conns tasklets with TASK_F_USR1
5575 - MINOR: xprt: add new xprt_set_idle and xprt_set_used methods
5576 - MEDIUM: ssl: implement xprt_set_used and xprt_set_idle to relax context checks
5577 - MINOR: server: don't read curr_used_conns multiple times
5578 - CLEANUP: global: reorder some fields to respect cache lines
5579 - CLEANUP: sockpair: silence a coverity check about fcntl()
5580 - CLEANUP: lua: set a dummy file name and line number on the dummy servers
5581 - MINOR: server: add a global list of all known servers
5582 - MINOR: cfgparse: finish to set up servers outside of the proxy setup loop
5583 - MINOR: server: allocate a per-thread struct for the per-thread connections stuff
5584 - MINOR: server: move actconns to the per-thread structure
5585 - CLEANUP: server: reorder some fields in the server struct to respect cache lines
5586 - MINOR: backend: add a BUG_ON if conn mux NULL in connect_server
5587 - BUG/MINOR: backend: fix condition for reuse on mode HTTP
5588 - BUILD: Fix build when using clang without optimizing.
5589 - CLEANUP: assorted typo fixes in the code and comments
5590
Willy Tarreau8ab65c22021-02-26 22:49:10 +010055912021/02/26 : 2.4-dev10
5592 - BUILD: SSL: introduce fine guard for RAND_keep_random_devices_open
5593 - MINOR: Configure the `cpp` userdiff driver for *.[ch] in .gitattributes
5594 - BUG/MINOR: ssl/cli: potential null pointer dereference in "set ssl cert"
5595 - BUG/MINOR: sample: secure convs that accept base64 string and var name as args
5596 - BUG/MEDIUM: vars: make functions vars_get_by_{name,desc} thread-safe
5597 - CLEANUP: vars: make smp_fetch_var() to reuse vars_get_by_desc()
5598 - DOC: muxes: add a diagram of the exchanges between muxes and outer world
5599 - BUG/MEDIUM: proxy: use thread-safe stream killing on hard-stop
5600 - BUG/MEDIUM: cli/shutdown sessions: make it thread-safe
5601 - BUG/MINOR: proxy: wake up all threads when sending the hard-stop signal
5602 - MINOR: stream: add an "epoch" to figure which streams appeared when
5603 - MINOR: cli/streams: make "show sess" dump all streams till the new epoch
5604 - MINOR: streams: use one list per stream instead of a global one
5605 - MEDIUM: streams: do not use the streams lock anymore
5606 - BUILD: dns: avoid a build warning when threads are disabled (dss unused)
5607 - MEDIUM: task: remove the tasks_run_queue counter and have one per thread
5608 - MINOR: tasks: do not maintain the rqueue_size counter anymore
5609 - CLEANUP: tasks: use a less confusing name for task_list_size
5610 - CLEANUP: task: move the tree root detection from __task_wakeup() to task_wakeup()
5611 - MINOR: task: limit the remote thread wakeup to the global runqueue only
5612 - MINOR: task: move the allocated tasks counter to the per-thread struct
5613 - CLEANUP: task: split the large tasklet_wakeup_on() function in two
5614 - BUG/MINOR: fd: properly wait for !running_mask in fd_set_running_excl()
5615 - BUG/MINOR: resolvers: Fix condition to release received ARs if not assigned
5616 - BUG/MINOR: resolvers: Only renew TTL for SRV records with an additional record
5617 - BUG/MINOR: resolvers: new callback to properly handle SRV record errors
5618 - BUG/MEDIUM: resolvers: Reset server address and port for obselete SRV records
5619 - BUG/MEDIUM: resolvers: Reset address for unresolved servers
5620 - DOC: Update the module list in MAINTAINERS file
5621 - MINOR: htx: Add function to reserve the max possible size for an HTX DATA block
5622 - DOC: Update the HTX API documentation
5623 - DOC: Update the filters guide
5624 - BUG/MEDIUM: contrib/prometheus-exporter: fix segfault in listener name dump
5625 - MINOR: task: split the counts of local and global tasks picked
5626 - MINOR: task: do not use __task_unlink_rq() from process_runnable_tasks()
5627 - MINOR: task: don't decrement then increment the local run queue
5628 - CLEANUP: task: re-merge __task_unlink_rq() with task_unlink_rq()
5629 - MINOR: task: make grq_total atomic to move it outside of the grq_lock
5630 - MINOR: tasks: also compute the tasklet latency when DEBUG_TASK is set
5631 - MINOR: task: make tasklet wakeup latency measurements more accurate
5632 - MINOR: server: Be more strict on the server-state line parsing
5633 - MINOR: server: Only fill one array when parsing a server-state line
5634 - MEDIUM: server: Refactor apply_server_state() to make it more readable
5635 - CLEANUP: server: Rename state_line node to node instead of name_name
5636 - CLEANUP: server: Rename state_line structure into server_state_line
5637 - CLEANUP: server: Use a local eb-tree to store lines of the global server-state file
5638 - MINOR: server: Be more strict when reading the version of a server-state file
5639 - MEDIUM: server: Store parsed params of a server-state line in the tree
5640 - MINOR: server: Remove cached line from global server-state tree when found
5641 - MINOR: server: Move loading state of servers in a dedicated function
5642 - MEDIUM: server: Use a tree to store local server-state lines
5643 - MINOR: server: Parse and store server-state lines in a dedicated function
5644 - MEDIUM: server: Don't load server-state file if a line is corrupted
5645 - REORG: server: Export and rename some functions updating server info
5646 - REORG: server-state: Move functions to deal with server-state in its own file
5647 - MINOR: server-state: Don't load server-state file for serverless proxies
5648 - CLEANUP: muxes: Remove useless if condition in show_fd function
5649 - BUG/MINOR: stats: fix compare of no-maint url suffix
5650 - MINOR: task: limit the number of subsequent heavy tasks with flag TASK_HEAVY
5651 - MINOR: ssl: mark the SSL handshake tasklet as heavy
5652 - CLEANUP: server: rename srv_cleanup_{idle,toremove}_connections()
5653 - BUG/MINOR: ssl: potential null pointer dereference in ckchs_dup()
5654 - MINOR: task: add one extra tasklet class: TL_HEAVY
5655 - MINOR: task: place the heavy elements in TL_HEAVY
5656 - MINOR: task: only limit TL_HEAVY tasks but not others
5657 - BUG/MINOR: http-ana: Only consider dst address to process originalto option
5658 - MINOR: tools: Add net_addr structure describing a network addess
5659 - MINOR: tools: Add function to compare an address to a network address
5660 - MEDIUM: http-ana: Add IPv6 support for forwardfor and orignialto options
5661 - CLEANUP: hlua: Use net_addr structure internally to parse and compare addresses
5662 - REGTESTS: Add script to test except param for fowardedfor/originalto options
5663 - DOC: scheduler: add a diagram showing the different queues and their usages
5664 - CLEANUP: tree-wide: replace free(x);x=NULL with ha_free(&x)
5665 - CLEANUP: config: replace a few free() with ha_free()
5666 - CLEANUP: vars: always zero the pointers after a free()
5667 - CLEANUP: ssl: remove a useless "if" before freeing an error message
5668 - CLEANUP: ssl: make ssl_sock_free_srv_ctx() zero the pointers after free
5669 - CLEANUP: ssl: use realloc() instead of free()+malloc()
5670
Willy Tarreau31dd3932021-02-20 13:30:31 +010056712021/02/20 : 2.4-dev9
5672 - BUG/MINOR: server: Remove RMAINT from admin state when loading server state
5673 - CLEANUP: check: fix get_check_status_info declaration
5674 - CLEANUP: contrib/prometheus-exporter: align for with srv status case
5675 - MEDIUM: stats: allow to select one field in `stats_fill_li_stats`
5676 - MINOR: stats: add helper to get status string
5677 - MEDIUM: contrib/prometheus-exporter: add listen stats
5678 - BUG/MINOR: dns: add test on result getting value from buffer into ring.
5679 - BUG/MINOR: dns: dns_connect_server must return -1 unsupported nameserver's type
5680 - BUG/MINOR: dns: missing test writing in output channel in session handler
5681 - BUG/MINOR: dns: fix ring attach control on dns_session_new
5682 - BUG/MEDIUM: dns: fix multiple double close on fd in dns.c
5683 - BUG/MAJOR: connection: prevent double free if conn selected for removal
5684 - BUG/MINOR: session: atomically increment the tracked sessions counter
5685 - REGTESTS: fix http_reuse_conn_hash proxy test
5686 - BUG/MINOR: backend: do not call smp_make_safe for sni conn hash
5687 - MINOR: connection: remove pointers for prehash in conn_hash_params
5688 - BUG/MINOR: checks: properly handle wrapping time in __health_adjust()
5689 - BUG/MEDIUM: checks: don't needlessly take the server lock in health_adjust()
5690 - DEBUG: thread: add 5 extra lock labels for statistics and debugging
5691 - OPTIM: server: switch the actconn list to an mt-list
5692 - Revert "MINOR: threads: change lock_t to an unsigned int"
5693 - MINOR: lb/api: let callers of take_conn/drop_conn tell if they have the lock
5694 - OPTIM: lb-first: do not take the server lock on take_conn/drop_conn
5695 - OPTIM: lb-leastconn: do not take the server lock on take_conn/drop_conn
5696 - OPTIM: lb-leastconn: do not unlink the server if it did not change
5697 - MINOR: tasks: add DEBUG_TASK to report caller info in a task
5698 - MINOR: tasks/debug: add some extra controls of use-after-free in DEBUG_TASK
5699 - BUG/MINOR: sample: Always consider zero size string samples as unsafe
5700 - MINOR: cli: add missing agent commands for set server
5701 - BUILD/MEDIUM: da Adding pcre2 support.
5702 - BUILD: ssl: introduce fine guard for OpenSSL specific SCTL functions
5703 - REGTESTS: reorder reuse conn proxy protocol test
5704 - DOC: explain the relation between pool-low-conn and tune.idle-pool.shared
5705 - MINOR: tasks: refine the default run queue depth
5706 - MINOR: listener: refine the default MAX_ACCEPT from 64 to 4
5707 - MINOR: mux_h2: do not try to remove front conn from idle trees
5708 - REGTESTS: workaround for a crash with recent libressl on http-reuse sni
5709 - BUG/MEDIUM: lists: Avoid an infinite loop in MT_LIST_TRY_ADDQ().
5710 - MINOR: connection: allocate dynamically hash node for backend conns
5711 - DOC: DeviceAtlas documentation typo fix.
5712 - BUG/MEDIUM: spoe: Resolve the sink if a SPOE logs in a ring buffer
5713 - BUG/MINOR: http-rules: Always replace the response status on a return action
5714 - BUG/MINOR: server: Init params before parsing a new server-state line
5715 - BUG/MINOR: server: Be sure to cut the last parsed field of a server-state line
5716 - MEDIUM: server: Don't introduce a new server-state file version
5717 - DOC: contrib/prometheus-exporter: remove htx reference
5718 - REGTESTS: contrib/prometheus-exporter: test NaN values
5719 - REGTESTS: contrib/prometheus-exporter: test well known labels
5720 - CI: github actions: switch to stable LibreSSL release
5721 - BUG/MINOR: server: Fix test on number of fields allowed in a server-state line
5722 - MINOR: dynbuf: make the buffer wait queue per thread
5723 - MINOR: dynbuf: use regular lists instead of mt_lists for buffer_wait
5724 - MINOR: dynbuf: pass offer_buffers() the number of buffers instead of a threshold
5725 - MINOR: sched: have one runqueue ticks counter per thread
5726
Willy Tarreaudc626ec2021-02-13 10:17:27 +010057272021/02/13 : 2.4-dev8
5728 - BUILD: ssl: fix typo in HAVE_SSL_CTX_ADD_SERVER_CUSTOM_EXT macro
5729 - BUILD: ssl: guard SSL_CTX_add_server_custom_ext with special macro
5730 - BUG/MINOR: mux-h1: Don't emit extra CRLF for empty chunked messages
5731 - MINOR: contrib/prometheus-exporter: use stats desc when possible followup
5732 - MEDIUM: contrib/prometheus-exporter: export base stick table stats
5733 - CLEANUP: assorted typo fixes in the code and comments
5734 - CLEANUP: check: fix some typo in comments
5735 - CLEANUP: tools: typo in `strl2irc` mention
5736 - BUILD: ssl: guard SSL_CTX_set_msg_callback with SSL_CTRL_SET_MSG_CALLBACK macro
5737 - MEDIUM: ssl: add a rwlock for SSL server session cache
5738 - BUG/MINOR: intops: fix mul32hi()'s off-by-one
5739 - BUG/MINOR: freq_ctr: fix a wrong delay calculation in next_event_delay()
5740 - MINOR: stick-tables/counters: add http_fail_cnt and http_fail_rate data types
5741 - MINOR: ssl: add SSL_SERVER_LOCK label in threads.h
5742 - BUG/MINOR: mux-h1: Don't increment HTTP error counter for 408/500/501 errors
5743 - BUG/MINOR: http-ana: Don't increment HTTP error counter on internal errors
5744 - BUG/MEDIUM: mux-h1: Always set CS_FL_EOI for response in MSG_DONE state
5745 - BUG/MINOR: mux-h1: Fix data skipping for bodyless responses
5746 - BUG/MINOR: mux-h1: Don't blindly skip EOT block for non-chunked messages
5747 - BUG/MEDIUM: mux-h2: Add EOT block when EOM flag is set on an empty HTX message
5748 - MINOR: mux-h1: Be sure EOM flag is set when processing end of outgoing message
5749 - REGTESTS: Add a script to test payload skipping for bodyless HTTP responses
5750 - BUG/MINOR: server: re-align state file fields number
5751 - CLEANUP: muxes: Remove useless calls to b_realign_if_empty()
5752 - BUG/MINOR: tools: Fix a memory leak on error path in parse_dotted_uints()
5753 - CLEANUP: remove unused variable assigned found by Coverity
5754 - CLEANUP: queue: Remove useless tests on p or pp in pendconn_process_next_strm()
5755 - BUG/MINOR: backend: hold correctly lock when killing idle conn
5756 - MEDIUM: connection: protect idle conn lists with locks
5757 - MEDIUM: connection: replace idle conn lists by eb trees
5758 - MINOR: backend: search conn in idle/safe trees after available
5759 - MINOR: backend: search conn in idle tree after safe on always reuse
5760 - MINOR: connection: prepare hash calcul for server conns
5761 - MINOR: connection: use the srv pointer for the srv conn hash
5762 - MINOR: backend: compare conn hash for session conn reuse
5763 - MINOR: connection: use sni as parameter for srv conn hash
5764 - MINOR: reg-tests: test http-reuse with sni
5765 - MINOR: backend: rewrite alloc of stream target address
5766 - MINOR: connection: use dst addr as parameter for srv conn hash
5767 - MINOR: reg-test: test http-reuse with specific dst addr
5768 - MINOR: backend: rewrite alloc of connection src address
5769 - MINOR: connection: use src addr as parameter for srv conn hash
5770 - MINOR: connection: use proxy protocol as parameter for srv conn hash
5771 - MINOR: reg-tests: test http-reuse with proxy protocol
5772 - MINOR: doc: update http reuse for new eligilible connections
5773 - BUG/MINOR: backend: fix compilation without ssl
5774 - REGTESTS: adjust http_reuse_conn_hash requirements
5775 - REGTESTS: deactivate a failed test on CI in http_reuse_conn_hash
5776 - REGTESTS: fix sni used in http_reuse_conn_hash for libressl 3.3.0
5777 - CI: cirrus: update FreeBSD image to 12.2
5778 - MEDIUM: cli: add check-addr command
5779 - MEDIUM: cli: add agent-port command
5780 - MEDIUM: server: add server-states version 2
5781 - MEDIUM: server: support {check,agent}_addr, agent_port in server state
5782 - MINOR: server: enhance error precision when applying server state
5783 - BUG/MINOR: server: Fix server-state-file-name directive
5784 - CLEANUP: deinit: release global and per-proxy server-state variables on deinit
5785 - BUG/MEDIUM: config: don't pick unset values from last defaults section
5786 - BUG/MINOR: stats: revert the change on ST_CONVDONE
5787 - BUG/MINOR: cfgparse: do not mention "addr:port" as supported on proxy lines
5788 - BUG/MINOR: http-htx: defpx must be a const in proxy_dup_default_conf_errors()
5789 - BUG/MINOR: tcpheck: the source list must be a const in dup_tcpcheck_var()
5790 - BUILD: proxy: add missing compression-t.h to proxy-t.h
5791 - REORG: move init_default_instance() to proxy.c and pass it the defproxy pointer
5792 - REORG: proxy: centralize the proxy allocation code into alloc_new_proxy()
5793 - MEDIUM: proxy: only take defaults when a default proxy is passed.
5794 - MINOR: proxy: move the defproxy freeing code to proxy.c
5795 - MINOR: proxy: always properly reset the just freed default instance pointers
5796 - BUG/MINOR: extcheck: proxy_parse_extcheck() must take a const for the defproxy
5797 - BUG/MINOR: tcpcheck: proxy_parse_*check*() must take a const for the defproxy
5798 - BUG/MINOR: server: parse_server() must take a const for the defproxy
5799 - MINOR: cfgparse: move defproxy to cfgparse-listen as a static
5800 - MINOR: proxy: add a new capability PR_CAP_DEF
5801 - MINOR: cfgparse: check PR_CAP_DEF instead of comparing poiner against defproxy
5802 - MINOR: cfgparse: use a pointer to the current default proxy
5803 - MINOR: proxy: also store the name for a defaults section
5804 - MINOR: proxy: support storing defaults sections into their own tree
5805 - MEDIUM: proxy: store the default proxies in a tree by name
5806 - MEDIUM: cfgparse: allow a proxy to designate the defaults section to use
5807 - MINOR: http: add baseq sample fetch
5808 - CLEANUP: tcpcheck: Remove a useless test on port variable
5809 - BUG/MINOR: server: Don't call fopen() with server-state filepath set to NULL
5810 - CLEANUP: server: Remove useless "filepath" variable in apply_server_state()
5811 - MINOR: peers/cli: do not dump the peers dictionaries by default on "show peers"
5812 - MINOR: cfgparse: implement a simple if/elif/else/endif macro block handler
5813 - DOC: tune: explain the origin of block size for ssl.cachesize
5814 - MINOR: tcp: add support for defer-accept on FreeBSD.
5815 - MINOR: ring: adds new ring_init function.
5816 - CLEANUP: channel: fix comment in ci_putblk.
5817 - BUG/MINOR: dns: add missing sent counter and parent id to dns counters.
5818 - BUG/MINOR: resolvers: fix attribute packed struct for dns
5819 - MINOR: resolvers: renames some resolvers internal types and removes dns prefix
5820 - MINOR: resolvers: renames type dns_resolvers to resolvers.
5821 - MINOR: resolvers: renames some resolvers specific types to not use dns prefix
5822 - MINOR: resolvers: renames some dns prefixed types using resolv prefix.
5823 - MINOR: resolvers: renames resolvers DNS_RESP_* errcodes RSLV_RESP_*
5824 - MINOR: resolvers: renames resolvers DNS_UPD_* returncodes to RSLV_UPD_*
5825 - MINOR: resolvers: rework prototype suffixes to split resolving and dns.
5826 - MEDIUM: resolvers: move resolvers section parsing from cfgparse.c to dns.c
5827 - MINOR: resolvers: replace nameserver's resolver ref by generic parent pointer
5828 - MINOR: resolvers: rework dns stats prototype because specific to resolvers
5829 - MEDIUM: resolvers: split resolving and dns message exchange layers.
5830 - MEDIUM: resolvers/dns: split dns.c into dns.c and resolvers.c
5831 - MEDIUM: dns: adds code to support pipelined DNS requests over TCP.
5832 - MEDIUM: resolvers: add supports of TCP nameservers in resolvers.
5833
Willy Tarreau5d46fbd2021-02-05 15:17:33 +010058342021/02/05 : 2.4-dev7
5835 - BUG/MINOR: stats: Continue to fill frontend stats on unimplemented metric
5836 - BUILD: ssl: guard Client Hello callbacks with HAVE_SSL_CLIENT_HELLO_CB macro instead of openssl version
5837 - BUG/MINOR: stats: Init the metric variable when frontend stats are filled
5838 - MINOR: contrib/prometheus-exporter: better output of Not-a-Number
5839 - CLEANUP: stats: improve field selection for frontend http fields
5840 - CLEANUP: assorted typo fixes in the code and comments
5841 - DOC: Improve documentation of the various hdr() fetches
5842 - MEDIUM: stats: allow to select one field in `stats_fill_be_stats`
5843 - MINOR: contrib/prometheus-exporter: use fill_be_stats for backend dump
5844 - MEDIUM: stats: allow to select one field in `stats_fill_sv_stats`
5845 - MINOR: contrib/prometheus-exporter: use fill_sv_stats for server dump
5846 - MINOR: abort() on my_unreachable() when DEBUG_USE_ABORT is set.
5847 - BUG/MEDIUM: filters/htx: Fix data forwarding when payload length is unknown
5848 - BUG/MINOR: config: fix leak on proxy.conn_src.bind_hdr_name
5849 - MINOR: reg-tests: add http-reuse test
5850 - CLEANUP: srv: fix comment for pool-max-conn
5851 - CLEANUP: backend: remove an obsolete comment on conn_backend_get
5852 - REORG: backend: simplify conn_backend_get
5853 - MINOR: ssl: Server ssl context prepare function refactoring
5854 - MINOR: ssl: Certificate chain loading refactorization
5855 - MEDIUM: ssl: Load client certificates in a ckch for backend servers
5856 - MEDIUM: ssl: Enable backend certificate hot update
5857 - MINOR: ssl: Remove client_crt member of the server's ssl context
5858 - CLEANUP: ssl/cli: rework free in cli_io_handler_commit_cert()
5859 - CLEANUP: ssl: remove SSL_CTX function parameter
5860 - CLEANUP: ssl: make load_srv_{ckchs,cert} match their bind counterpart
5861 - BUILD: Include stdlib.h in compiler.h if DEBUG_USE_ABORT is set
5862 - CI: Fix DEBUG_STRICT definition for Coverity
5863 - BUG/MINOR: stats: Remove a break preventing ST_F_QCUR to be set for servers
5864 - BUG/MINOR: stats: Add a break after filling ST_F_MODE field for servers
5865 - CLEANUP: ssl: remove dead code in ckch_inst_new_load_srv_store()
5866 - BUG/MINOR: ssl: init tmp chunk correctly in ssl_sock_load_sctl_from_file()
5867 - BUG/MEDIUM: session: only retrieve ready idle conn from session
5868 - BUG/MEDIUM: backend: never reuse a connection for tcp mode
5869 - REGTESTS: set_ssl_server_cert.vtc: remove the abort command
5870 - REGTESTS: set_ssl_server_cert.vtc: check the Sha1 Fingerprint
5871 - REGTESTS: set_ssl_server_cert.vtc: check the sha1 from the server
5872 - MEDIUM: stream-int: Take care of EOS if the SI wake callback function
5873 - MINOR: mux-h1: Try to wake up data layer first before calling its wake callback
5874 - MINOR: mux-h1: Wake up H1C after its creation if input buffer is not empty
5875 - MEDIUM: mux-h1: Add ST_READY state for the H1 connections
5876 - MINOR: stream: Add a function to validate TCP to H1 upgrades
5877 - MEDIUM: http-ana: Do nothing in wait-for-request analyzer if not htx
5878 - BUG/MEDIUM: stream: Don't immediatly ack the TCP to H1 upgrades
5879 - BUG/MAJOR: mux-h1: Properly handle TCP to H1 upgrades
5880 - MINOR: htx/http-ana: Save info about Upgrade option in the Connection header
5881 - MEDIUM: http-ana: Refuse invalid 101-switching-protocols responses
5882 - BUG/MINOR: h2/mux-h2: Reject 101 responses with a PROTOCOL_ERROR h2s error
5883 - MINOR: mux-h1/mux-fcgi: Don't set TUNNEL mode if payload length is unknown
5884 - MINOR: mux-h1: Split H1C_F_WAIT_OPPOSITE flag to separate input/output sides
5885 - MINOR: mux-h2: Add 2 flags to help to properly handle tunnel mode
5886 - MEDIUM: mux-h2: Block client data on server side waiting tunnel establishment
5887 - MEDIUM: mux-h2: Close streams when processing data for an aborted tunnel
5888 - MEDIUM: mux-h1: Properly handle tunnel establishments and aborts
5889 - BUG/MAJOR: mux-h1/mux-h2/htx: Fix HTTP tunnel management at the mux level
5890 - MINOR: htx: Rename HTX_FL_EOI flag into HTX_FL_EOM
5891 - REGTESTS: Don't run http_msg_full_on_eom script on the 2.4 anymore
5892 - MINOR: htx: Add a function to know if a block is the only one in a message
5893 - MAJOR: htx: Remove the EOM block type and use HTX_FL_EOM instead
5894 - MINOR: mux-h1: Add a flag on H1 streams with a response known to be bodyless
5895 - MEDIUM: mux-h1: Don't emit any payload for bodyless responses
5896 - MINOR: mux-h1: Don't emit C-L and T-E headers for 204 and 1xx responses
5897 - MINOR: mux-h1: Don't add Connection close/keep-alive header for 1xx messages
5898 - MINOR: h2/mux-h2: Add flags to notify the response is known to have no body
5899 - MEDIUM: mux-h2: Don't emit DATA frame for bodyless responses
5900 - MEDIUM: http-ana: Deal with L7 retries in HTTP analysers
5901 - MINOR: h1: reject websocket handshake if missing key
5902 - MEDIUM: h1: generate WebSocket key on response if needed
5903 - MINOR: mux_h2: define H2_SF_EXT_CONNECT_SENT stream flag
5904 - MEDIUM: h2: parse Extended CONNECT reponse to htx
5905 - MEDIUM: mux_h2: generate Extended CONNECT from htx upgrade
5906 - MEDIUM: h1: add a WebSocket key on handshake if needed
5907 - MEDIUM: mux_h2: generate Extended CONNECT response
5908 - MEDIUM: h2: parse Extended CONNECT request to htx
5909 - MEDIUM: h2: send connect protocol h2 settings
5910 - MINOR: vtc: add test for h1/h2 protocol upgrade translation
5911 - MINOR: vtc: add websocket test
5912 - REGTESTS: Fix required versions for several scripts
5913 - REGTEST: Don't use the websocket to validate http-check
5914 - MINOR: mux-h1/trace: add traces at level ERROR for all kind of errors
5915 - MINOR: mux-fcgi/trace: add traces at level ERROR for all kind of errors
5916 - MINOR: h1: Raise the chunk size limit up to (2^52 - 1)
5917 - BUG/MEDIUM: listener: do not accept connections faster than we can process them
5918 - REGTESTS: set_ssl_server_cert.vtc: set as broken
5919 - Revert "BUG/MEDIUM: listener: do not accept connections faster than we can process them"
5920 - BUG/MINOR: backend: check available list allocation for reuse
5921 - CI: Fix the coverity builds
5922 - DOC: management: fix "show resolvers" alphabetical ordering
5923 - MINOR: tools: add print_time_short() to print a condensed duration value
5924 - MINOR: activity: make profiling more manageable
5925 - MINOR: activity: declare a new structure to collect per-function activity
5926 - MEDIUM: tasks/activity: collect per-task statistics when profiling is enabled
5927 - MINOR: activity: also report collected tasks stats in "show profiling"
5928 - MINOR: activity: flush scheduler stats on "set profiling tasks on"
5929 - MINOR: activity: add a new "show tasks" command to list currently active tasks
5930 - MINOR: listener: export accept_queue_process
5931 - MINOR: session: export session_expire_embryonic()
5932 - MINOR: muxes: export the timeout and shutr task handlers
5933 - MINOR: checks: export a few functions that appear often in trace dumps
5934 - MINOR: peers: export process_peer_sync() to improve traces
5935 - MINOR: stick-tables: export process_table_expire()
5936 - MINOR: mux-h1: Remove first useless test on count in h1_process_output()
5937 - BUG/MINOR: stick-table: Always call smp_fetch_src() with a valid arg list
5938 - MINOR: http-fetch: Don't check if argument list is set in sample fetches
5939 - MINOR: http-conv: Don't check if argument list is set in sample converters
5940 - MINOR: sample: Don't check if argument list is set in sample fetches
5941 - MINOR: ssl-sample: Don't check if argument list is set in sample fetches
5942 - MINOR: mux-h2: Don't tests the start-line when sending HEADERS frame
5943 - MINOR: mux-h2: Slightly improve request HEADERS frames sending
5944 - MINOR: contrib/prometheus-exporter: declare states for objects
5945 - MAJOR: contrib/prometheus-exporter: move ftd/bkd/srv states to labels
5946 - MEDIUM: contrib/prometheus-exporter: Use dynamic labels instead of static ones
5947 - MINOR: listener: export manage_global_listener_queue()
5948 - BUG/MINOR: activity: take care of late wakeups in "show tasks"
5949 - REGTESTS: set_ssl_server_cert.vtc: remove SSL caching and set as working
5950 - REGTESTS: set_ssl_server_cert: cleanup the SSL caching option
5951 - MINOR: checks: Add function to get the result code corresponding to a status
5952 - MAJOR: contrib/prometheus-exporter: move health check status to labels
5953 - MINOR: contrib/prometheus-exporter: improve service status description field
5954 - MINOR: stats: improve pending connections description
5955 - MINOR: stats: improve max stats descriptions
5956 - MINOR: contrib/prometheus-exporter: use stats desc when possible
5957 - MINOR: contrib/prometheus-exporter: add uweight field
5958 - MINOR: contrib/prometheus-exporter: add recv logs_logs_total field
5959 - CLEANUP: contrib/prometheus-exporter: remove unused includes
5960 - CLEANUP: contrib/prometheus-exporter: align and reorder fields
5961 - CLEANUP: contrib/prometheus-exporter: remove description in README
5962 - DOC: contrib/prometheus-exporter: Add missing metrics in README
5963 - BUG/MINOR: contrib/prometheus-exporter: Add missing label for ST_F_HRSP_1XX
5964 - BUG/MINOR: contrib/prometheus-exporter: Restart labels dump at the right pos
5965 - BUG/MEDIUM: ssl/cli: abort ssl cert is freeing the old store
5966 - BUG/MEDIUM: ssl: check a connection's status before computing a handshake
5967 - BUG/MINOR: mux_h2: fix incorrect stat titles
5968 - MINOR: ssl/cli: flush the server session cache upon 'commit ssl cert'
5969 - BUG/MINOR: cli: fix set server addr/port coherency with health checks
5970 - MINOR: server: Don't set the check port during the update from a state file
5971 - MINOR: dns: Don't set the check port during a server dns resolution
5972 - MEDIUM: check: remove checkport checkaddr flag
5973 - MEDIUM: server: adding support for check_port in server state
5974 - BUG/MINOR: check: consitent way to set agentaddr
5975 - MEDIUM: check: align agentaddr and agentport behaviour
5976 - DOC: server: Add missing params in comment of the server state line parsing
5977 - BUG/MINOR: xxhash: make sure armv6 uses memcpy()
5978 - REGTESTS: mark http-check-send.vtc as 2.4-only
5979 - REGTESTS: mark sample_fetches/hashes.vtc as 2.4-only
5980 - BUG/MINOR: ssl: do not try to use early data if not configured
5981 - REGTESTS: unbreak http-check-send.vtc
5982 - MINOR: cli/show_fd: report local and report ports when known
5983 - BUILD: Makefile: move REGTESTST_TYPE default setting
5984 - BUG/MEDIUM: mux-h2: handle remaining read0 cases
5985 - CLEANUP: http-htx: Set buffer area to NULL instead of malloc(0)
5986 - BUG/MINOR: sock: Unclosed fd in case of connection allocation failure
5987 - BUG/MEDIUM: mux-h2: do not quit the demux loop before setting END_REACHED
5988
Willy Tarreau24c41d52021-01-22 16:19:46 +010059892021/01/22 : 2.4-dev6
5990 - MINOR: converter: adding support for url_enc
5991 - BUILD: SSL: guard TLS13 ciphersuites with HAVE_SSL_CTX_SET_CIPHERSUITES
5992 - BUILD: ssl: guard EVP_PKEY_get_default_digest_nid with ASN1_PKEY_CTRL_DEFAULT_MD_NID
5993 - BUILD: ssl: guard openssl specific with SSL_READ_EARLY_DATA_SUCCESS
5994 - BUILD: Makefile: exclude broken tests by default
5995 - CLEANUP: cfgparse: replace "realloc" with "my_realloc2" to fix to memory leak on error
5996 - BUG/MINOR: hlua: Fix memory leak in hlua_alloc
5997 - MINOR: contrib/prometheus-exporter: export build_info
5998 - DOC: fix some spelling issues over multiple files
5999 - CLEANUP: Fix spelling errors in comments
6000 - SCRIPTS: announce-release: fix typo in help message
6001 - CI: github: add a few more words to the codespell ignore list
6002 - DOC: Add maintainers for the Prometheus exporter
6003 - BUG/MINOR: sample: fix concat() converter's corruption with non-string variables
6004 - BUG/MINOR: server: Memory leak of proxy.used_server_addr during deinit
6005 - CLEANUP: sample: remove uneeded check in json validation
6006 - MINOR: reg-tests: add a way to add service dependency
6007 - BUG/MINOR: sample: check alloc_trash_chunk return value in concat()
6008 - BUG/MINOR: reg-tests: fix service dependency script
6009 - MINOR: reg-tests: add base prometheus test
6010 - Revert "BUG/MINOR: dns: SRV records ignores duplicated AR records"
6011 - BUG/MINOR: sample: Memory leak of sample_expr structure in case of error
6012 - BUG/MINOR: check: Don't perform any check on servers defined in a frontend
6013 - BUG/MINOR: init: enforce strict-limits when using master-worker
6014 - MINOR: contrib/prometheus-exporter: avoid connection close header
6015 - MINOR: contrib/prometheus-exporter: use fill_info for process dump
6016 - BUG/MINOR: init: Use a dynamic buffer to set HAPROXY_CFGFILES env variable
6017 - MINOR: config: Add failifnotcap() to emit an alert on proxy capabilities
6018 - MINOR: server: Forbid server definitions in frontend sections
6019 - BUG/MINOR: threads: Fixes the number of possible cpus report for Mac.
6020 - CLEANUP: pattern: rename pat_ref_commit() to pat_ref_commit_elt()
6021 - MINOR: pattern: add the missing generation ID manipulation functions
6022 - MINOR: peers: Add traces for peer control messages.
6023 - BUG/MINOR: dns: SRV records ignores duplicated AR records (v2)
6024 - BUILD: peers: fix build warning about unused variable
6025 - BUG/MEDIUM: stats: add missing INF_BUILD_INFO definition
6026 - MINOR: cache: Do not store responses with an unknown encoding
6027 - BUG/MINOR: peers: Possible appctx pointer dereference.
6028 - MINOR: build: discard echoing in help target
6029 - MINOR: cache: Remove the `hash` part of the accept-encoding secondary key
6030 - CLEANUP: cache: Use proper data types in secondary_key_cmp()
6031 - CLEANUP: Rename accept_encoding_hash_cmp to accept_encoding_bitmap_cmp
6032 - BUG/MINOR: peers: Wrong "new_conn" value for "show peers" CLI command.
6033 - MINOR: contrib: Make the wireshark peers dissector compile for more distribs.
6034 - BUG/MINOR: mux_h2: missing space between "st" and ".flg" in the "show fd" helper
6035 - CLEANUP: tools: make resolve_sym_name() take a const pointer
6036 - CLEANUP: cli: make "show fd" use a const connection to access other fields
6037 - MINOR: cli: make "show fd" also report the xprt and xprt_ctx
6038 - MINOR: xprt: add a new show_fd() helper to complete some "show fd" dumps.
6039 - MINOR: ssl: provide a "show fd" helper to report important SSL information
6040 - MINOR: xprt/mux: export all *_io_cb functions so that "show fd" resolves them
6041 - MINOR: mux-h2: make the "show fd" helper also decode the h2s subscriber when known
6042 - MINOR: mux-h1: make the "show fd" helper also decode the h1s subscriber when known
6043 - MINOR: mux-fcgi: make the "show fd" helper also decode the fstrm subscriber when known
6044 - CI: Pin VTest to a known good commit
6045 - MINOR: cli: give the show_fd helpers the ability to report a suspicious entry
6046 - MINOR: cli/show_fd: report some easily detectable suspicious states
6047 - MINOR: ssl/show_fd: report some FDs as suspicious when possible
6048 - MINOR: mux-h2/show_fd: report as suspicious an entry with too many calls
6049 - MINOR: mux-h1/show_fd: report as suspicious an entry with too many calls
6050 - BUG/MINOR: mworker: define _GNU_SOURCE for strsignal()
6051 - BUG/MEDIUM: tcpcheck: Don't destroy connection in the wake callback context
6052 - BUG/MEDIUM: mux-h2: Xfer rxbuf to the upper layer when creating a front stream
6053 - MINOR: http: Add HTTP 501-not-implemented error message
6054 - MINOR: muxes: Add exit status for errors about not implemented features
6055 - MINOR: mux-h1: Be prepared to return 501-not-implemented error during parsing
6056 - MEDIUM: mux-h1: Return a 501-not-implemented for upgrade requests with a body
6057 - DOC: Remove space after comma in converter signature
6058 - DOC: Rename '<var name>' to '<var>' in converter signature
6059 - MINOR: stats: duplicate 3 fields in bytes in info
6060 - MINOR: stats: add new start time field
6061 - MINOR: contrib/prometheus-exporter: merge info description from stats
6062 - MEDIUM: stats: allow to select one field in `stats_fill_fe_stats`
6063 - MINOR: contrib/prometheus-exporter: use fill_fe_stats for frontend dump
6064 - MINOR: contrib/prometheus-exporter: Don't needlessly set empty label for metrics
6065 - MINOR: contrib/prometheus-exporter: Split the PROMEX_FL_STATS_METRIC flag
6066 - MINOR: contrib/prometheus-exporter: Add promex_metric struct defining a metric
6067 - MEDIUM: contrib/prometheus-exporter: Rework matrices defining Promex metrics
6068 - BUG/MINOR: stream: Don't update counters when TCP to H2 upgrades are performed
6069 - BUG/MEDIUM: mux-h2: fix read0 handling on partial frames
6070 - MINOR: debug: always export the my_backtrace function
6071 - MINOR: debug: extract the backtrace dumping code to its own function
6072 - MINOR: debug: create ha_backtrace_to_stderr() to dump an instant backtrace
6073 - MEDIUM: debug: now always print a backtrace on CRASH_NOW() and friends
6074 - MINOR: debug: let ha_dump_backtrace() dump a bit further for some callers
6075 - BUILD: debug: fix build warning by consuming the write() result
6076 - MINOR: lua: remove unused variable
6077 - BUILD/MINOR: lua: define _GNU_SOURCE for LLONG_MAX
6078
Willy Tarreau421ed392021-01-06 17:41:32 +010060792021/01/06 : 2.4-dev5
6080 - BUG/MEDIUM: mux_h2: Add missing braces in h2_snd_buf()around trace+wakeup
6081 - BUILD: hpack: hpack-tbl-t.h uses VAR_ARRAY but does not include compiler.h
6082 - MINOR: time: increase the minimum wakeup interval to 60s
6083 - MINOR: check: do not ignore a connection header for http-check send
6084 - REGTESTS: complete http-check test
6085 - CI: travis-ci: drop coverity scan builds
6086 - MINOR: atomic: don't use ; to separate instruction on aarch64.
6087 - IMPORT: xxhash: update to v0.8.0 that introduces stable XXH3 variant
6088 - MEDIUM: xxhash: use the XXH3 functions to generate 64-bit hashes
6089 - MEDIUM: xxhash: use the XXH_INLINE_ALL macro to inline all functions
6090 - CLEANUP: xxhash: remove the unused src/xxhash.c
6091 - MINOR: sample: add the xxh3 converter
6092 - REGTESTS: add tests for the xxh3 converter
6093 - MINOR: protocol: Create proto_quic QUIC protocol layer.
6094 - MINOR: connection: Attach a "quic_conn" struct to "connection" struct.
6095 - MINOR: quic: Redefine control layer callbacks which are QUIC specific.
6096 - MINOR: ssl_sock: Initialize BIO and SSL objects outside of ssl_sock_init()
6097 - MINOR: connection: Add a new xprt to connection.
6098 - MINOR: ssl: Export definitions required by QUIC.
6099 - MINOR: cfgparse: Do not modify the QUIC xprt when parsing "ssl".
6100 - MINOR: tools: Add support for QUIC addresses parsing.
6101 - MINOR: quic: Add definitions for QUIC protocol.
6102 - MINOR: quic: Import C source code files for QUIC protocol.
6103 - MINOR: listener: Add QUIC info to listeners and receivers.
6104 - MINOR: server: Add QUIC definitions to servers.
6105 - MINOR: ssl: SSL CTX initialization modifications for QUIC.
6106 - MINOR: ssl: QUIC transport parameters parsing.
6107 - MINOR: quic: QUIC socket management finalization.
6108 - MINOR: cfgparse: QUIC default server transport parameters init.
6109 - MINOR: quic: Enable the compilation of QUIC modules.
6110 - MAJOR: quic: Make usage of ebtrees to store QUIC ACK ranges.
6111 - MINOR: quic: Attempt to make trace more readable
6112 - MINOR: quic: Make usage of the congestion control window.
6113 - MINOR: quic: Flag RX packet as ack-eliciting from the generic parser.
6114 - MINOR: quic: Code reordering to help in reviewing/modifying.
6115 - MINOR: quic: Add traces to congestion avoidance NewReno callback.
6116 - MINOR: quic: Display the SSL alert in ->ssl_send_alert() callback.
6117 - MINOR: quic: Update the initial salt to that of draft-29.
6118 - MINOR: quic: Add traces for in flght ack-eliciting packet counter.
6119 - MINOR: quic: make a packet build fails when qc_build_frm() fails.
6120 - MINOR: quic: Add traces for quic_packet_encrypt().
6121 - MINOR: cache: Refactoring of secondary_key building functions
6122 - MINOR: cache: Avoid storing responses whose secondary key was not correctly calculated
6123 - BUG/MINOR: cache: Manage multiple headers in accept-encoding normalization
6124 - MINOR: cache: Add specific secondary key comparison mechanism
6125 - MINOR: http: Add helper functions to trim spaces and tabs
6126 - MEDIUM: cache: Manage a subset of encodings in accept-encoding normalizer
6127 - REGTESTS: cache: Simplify vary.vtc file
6128 - REGTESTS: cache: Add a specific test for the accept-encoding normalizer
6129 - MINOR: cache: Remove redundant test in http_action_req_cache_use
6130 - MINOR: cache: Replace the "process-vary" option's expected values
6131 - CI: GitHub Actions: enable daily Coverity scan
6132 - BUG/MEDIUM: cache: Fix hash collision in `accept-encoding` handling for `Vary`
6133 - MEDIUM: stick-tables: Add srvkey option to stick-table
6134 - REGTESTS: add test for stickiness using "srvkey addr"
6135 - BUILD: Makefile: disable -Warray-bounds until it's fixed in gcc 11
6136 - BUG/MINOR: sink: Return an allocation failure in __sink_new if strdup() fails
6137 - BUG/MINOR: lua: Fix memory leak error cases in hlua_config_prepend_path
6138 - MINOR: lua: Use consistent error message 'memory allocation failed'
6139 - CLEANUP: Compare the return value of `XXXcmp()` functions with zero
6140 - CLEANUP: Apply the coccinelle patch for `XXXcmp()` on include/
6141 - CLEANUP: Apply the coccinelle patch for `XXXcmp()` on contrib/
6142 - MINOR: qpack: Add static header table definitions for QPACK.
6143 - CLEANUP: qpack: Wrong comment about the draft for QPACK static header table.
6144 - CLEANUP: quic: Remove useless QUIC event trace definitions.
6145 - BUG/MINOR: quic: Possible CRYPTO frame building errors.
6146 - MINOR: quic: Pass quic_conn struct to frame parsers.
6147 - BUG/MINOR: quic: Wrong STREAM frames parsing.
6148 - MINOR: quic: Drop packets with STREAM frames with wrong direction.
6149 - CLEANUP: ssl: Remove useless loop in tlskeys_list_get_next()
6150 - CLEANUP: ssl: Remove useless local variable in tlskeys_list_get_next()
6151 - MINOR: ssl: make tlskeys_list_get_next() take a list element
6152 - Revert "BUILD: Makefile: disable -Warray-bounds until it's fixed in gcc 11"
6153 - BUG/MINOR: cfgparse: Fail if the strdup() for `rule->be.name` for `use_backend` fails
6154 - CLEANUP: mworker: remove duplicate pointer tests in cfg_parse_program()
6155 - CLEANUP: Reduce scope of `header_name` in http_action_store_cache()
6156 - CLEANUP: Reduce scope of `hdr_age` in http_action_store_cache()
6157 - CLEANUP: spoe: fix typo on `var_check_arg` comment
6158 - BUG/MINOR: tcpcheck: Report a L7OK if the last evaluated rule is a send rule
6159 - CI: github actions: build several popular "contrib" tools
6160 - DOC: Improve the message printed when running `make` w/o `TARGET`
6161 - BUG/MEDIUM: server: srv_set_addr_desc() crashes when a server has no address
6162 - REGTESTS: add unresolvable servers to srvkey-addr
6163 - BUG/MINOR: stats: Make stat_l variable used to dump a stat line thread local
6164 - BUG/MINOR: quic: NULL pointer dereferences when building post handshake frames.
6165 - SCRIPTS: improve announce-release to support different tag and versions
6166 - SCRIPTS: make announce release support preparing announces before tag exists
6167 - CLEANUP: assorted typo fixes in the code and comments
6168 - BUG/MINOR: srv: do not init address if backend is disabled
6169 - BUG/MINOR: srv: do not cleanup idle conns if pool max is null
6170 - CLEANUP: assorted typo fixes in the code and comments
6171 - CLEANUP: few extra typo and fixes over last one ("ot" -> "to")
6172
Willy Tarreau4d711762020-12-21 11:54:56 +010061732020/12/21 : 2.4-dev4
6174 - BUG/MEDIUM: lb-leastconn: Reposition a server using the right eweight
6175 - BUG/MEDIUM: mux-h1: Fix a deadlock when a 408 error is pending for a client
6176 - BUG/MEDIUM: ssl/crt-list: bad behavior with "commit ssl cert"
6177 - BUG/MAJOR: cache: Crash because of disabled entry not removed from the tree
6178 - BUILD: SSL: fine guard for SSL_CTX_add_server_custom_ext call
6179 - MEDIUM: cache: Add a secondary entry counter and insertion limitation
6180 - MEDIUM: cache: Avoid going over duplicates lists too often
6181 - MINOR: cache: Add a max-secondary-entries cache option
6182 - CI: cirrus: drop CentOS 6 builds
6183 - BUILD: Makefile: have "make clean" destroy .o/.a/.s in contrib subdirs as well
6184 - MINOR: vars: replace static functions with global ones
6185 - MINOR: opentracing: add ARGC_OT enum
6186 - CONTRIB: opentracing: add the OpenTracing filter
6187 - DOC: opentracing: add the OpenTracing filter section
6188 - REGTESTS: make use of HAPROXY_ARGS and pass -dM by default
6189 - BUG/MINOR: http: Establish a tunnel for all 2xx responses to a CONNECT
6190 - BUG/MINOR: mux-h1: Don't set CS_FL_EOI too early for protocol upgrade requests
6191 - BUG/MEDIUM: http-ana: Never for sending data in TUNNEL mode
6192 - CLEANUP: mux-h2: Rename h2s_frt_make_resp_data() to be generic
6193 - CLEANUP: mux-h2: Rename h2c_frt_handle_data() to be generic
6194 - BUG/MEDIUM: mux-h1: Handle h1_process() failures on a pipelined request
6195 - CLEANUP: debug: mark the RNG's seed as unsigned
6196 - CONTRIB: halog: fix build issue caused by %L printf format
6197 - CONTRIB: halog: mark the has_zero* functions unused
6198 - CONTRIB: halog: fix signed/unsigned build warnings on counts and timestamps
6199 - CONTRIB: debug: address "poll" utility build on non-linux platforms
6200 - BUILD: plock: remove dead code that causes a warning in gcc 11
6201 - BUILD: ssl: fine guard for SSL_CTX_get0_privatekey call
6202 - BUG/MINOR: dns: SRV records ignores duplicated AR records
6203 - DOC: fix "smp_size" vs "sample_size" in "log" directive arguments
6204 - CLEANUP: assorted typo fixes in the code and comments
6205 - DOC: assorted typo fixes in the documentation
6206 - CI: codespell: whitelist "te" and "nd" words
6207
Willy Tarreaua786c412020-12-11 17:22:51 +010062082020/12/11 : 2.4-dev3
6209 - MINOR: log: Logging HTTP path only with %HPO
6210 - BUG/MINOR: mux-h2/stats: make stream/connection proto errors more accurate
6211 - MINOR: traces: add a new level "error" below the "user" level
6212 - MINOR: mux-h2/trace: add traces at level ERROR for protocol errors
6213 - BUG/MINOR: mux-h2/stats: not all GOAWAY frames are errors
6214 - BUG/MINOR: lua: missing "\n" in error message
6215 - BUG/MINOR: lua: lua-load doesn't check its parameters
6216 - BUG/MINOR: lua: Post init register function are not executed beyond the first one
6217 - BUG/MINOR: lua: Some lua init operation are processed unsafe
6218 - MINOR: actions: Export actions lookup functions
6219 - MINOR: actions: add a function returning a service pointer from its name
6220 - MINOR: cli: add a function to look up a CLI service description
6221 - BUG/MINOR: lua: warn when registering action, conv, sf, cli or applet multiple times
6222 - MINOR: cache: Improve accept_encoding_normalizer
6223 - MINOR: cache: Add entry to the tree as soon as possible
6224 - BUG/MINOR: trace: Wrong displayed trace level
6225 - BUG/MAJOR: ring: tcp forward on ring can break the reader counter.
6226 - MINOR: lua: simplify hlua_alloc() to only rely on realloc()
6227 - MEDIUM: lua-thread: use atomics for memory accounting
6228 - MINOR: lua-thread: remove struct hlua from function hlua_prepend_path()
6229 - MEDIUM: lua-thread: make hlua_post_init() no longer use the runtime execution function
6230 - MINOR: lua-thread: hlua_ctx_renew() is never called with main gL lua state
6231 - MINOR: lua-thread: Use NULL context for main lua state
6232 - MINOR: lua-thread: Stop usage of struct hlua for the global lua state
6233 - MINOR: lua-thread: Replace embedded struct hlua_function by a pointer
6234 - MINOR: lua-thread: Split hlua_init() function in two parts
6235 - MINOR: lua-thread: make hlua_ctx_init() get L from its caller
6236 - MINOR: lua-thread: Split hlua_load function in two parts
6237 - MINOR: lua-thread: Split hlua_post_init() function in two parts
6238 - MINOR: lua-thread: Add the "thread" core variable
6239 - MEDIUM: lua-thread: No longer use locked context in initialization parts
6240 - MEDIUM: lua-thread: Apply lock only if the parent state is the main thread
6241 - MINOR: lua-thread: Replace global gL var with an array of states
6242 - MINOR: lua-thread: Replace "struct hlua_function" allocation by dedicated function
6243 - MINOR: lua-thread: Replace state_from by state_id
6244 - MINOR: lua-thread: Store each function reference and init reference in array
6245 - MEDIUM: lua-thread: Add the lua-load-per-thread directive
6246 - MINOR: lua-thread: Add verbosity in errors
6247 - REGTESTS: add a test for the threaded Lua code
6248 - BUILD/MINOR: haproxy DragonFlyBSD affinity build update.
6249 - DOC/MINOR: Fix formatting in Management Guide
6250 - MINOR: cache: Do not store stale entry
6251 - MINOR: cache: Add extra "cache-control" value checks
6252 - MEDIUM: cache: Remove cache entry in case of POST on the same resource
6253 - MINOR: cache: Consider invalid Age values as stale
6254 - BUG/MEDIUM: lua-thread: some parts must be initialized once
6255 - BUG/MINOR: lua-thread: close all states on deinit
6256 - BUG/MINOR: listener: use sockaddr_in6 for IPv6
6257 - BUG/MINOR: mux-h1: Handle keep-alive timeout for idle frontend connections
6258 - MINOR: session: Add the idle duration field into the session
6259 - MINOR: mux-h1: Update session idle duration when data are received
6260 - MINOR: mux-h1: Reset session dates and durations info when the CS is detached
6261 - MINOR: logs: Use session idle duration when no stream is provided
6262 - MINOR: stream: Always get idle duration from the session
6263 - MINOR: stream: Don't retrieve anymore timing info from the mux csinfo
6264 - MINOR: mux-h1: Don't provide anymore timing info using cs_info structure
6265 - MINOR: muxes: Remove get_cs_info callback function now useless
6266 - MINOR: stream: Pass an optional input buffer when a stream is created
6267 - MINOR: mux-h1: Add a flag to disable reads to wait opposite side
6268 - MEDIUM: mux-h1: Use a h1c flag to block reads when splicing is in-progress
6269 - MINOR: mux-h1: Introduce H1C_F_IS_BACK flag on the H1 connection
6270 - MINOR: mux-h1: Separate parsing and formatting errors at H1 stream level
6271 - MINOR: mux-h1: Split front/back h1 stream creation in 2 functions
6272 - MINOR: mux-h1: Add a rxbuf into the H1 stream
6273 - MINOR: mux-h1: Don't set CS flags in internal parsing functions
6274 - MINOR: mux-h1: Add embryonic and attached states on the H1 connection
6275 - MINOR: mux-h1: rework the h1_timeout_task() function
6276 - MINOR: mux-h1: Reset more H1C flags when a H1 stream is destroyed
6277 - MINOR: mux-h1: Disable reads if an error was reported on the H1 stream
6278 - MINOR: mux-h1: Rework how shutdowns are handled
6279 - MINOR: mux-h1: Rework h1_refresh_timeout to be easier to read
6280 - MINOR: mux-h1: Process next request for IDLE connection only
6281 - MINOR: mux-h1: Add a idle expiration date on the H1 connection
6282 - MINOR: stick-tables: Add functions to update some values of a tracked counter
6283 - MINOR: session: Add functions to increase http values of tracked counters
6284 - MINOR: mux: Add a ctl parameter to get the exit status of the multiplexers
6285 - MINOR: logs: Get the multiplexer exist status when no stream is provided
6286 - MINOR: mux-h1: Add functions to send HTTP errors from the mux
6287 - MAJOR: mux-h1: Create the client stream as later as possible
6288 - DOC: config: Add notes about errors emitted by H1 mux
6289 - CLEANUP: mux-h1: Rename H1C_F_CS_* flags and reorder H1C flags
6290 - MINOR: http-ana: Remove useless update of t_idle duration of the stream
6291 - CLEANUP: htx: Remove HTX_FL_UPGRADE unsued flag
6292 - MEDIUM: http-ana: Don't process partial or empty request anymore
6293 - CLEANUP: http-ana: Remove TX_WAIT_NEXT_RQ unsued flag
6294 - CLEANUP: connection: Remove CS_FL_READ_PARTIAL flag
6295 - REGTESTS: Fix proxy_protocol_tlv_validation
6296 - MINOR: http-ana: Properly set message flags from the start-line flags
6297 - MINOR: h1-htx/http-ana: Set BODYLESS flag on message in TUNNEL state
6298 - MINOR: protocol: add a ->set_port() helper to address families
6299 - MINOR: listener: automatically set the port when creating listeners
6300 - MINOR: listener: now use a generic add_listener() function
6301 - MEDIUM: ssl: fatal error with bundle + openssl < 1.1.1
6302 - BUG/MEDIUM: stream: Xfer the input buffer to a fully created stream
6303 - BUG/MINOR: stream: Don't use input buffer after the ownership xfer
6304 - MINOR: protocol: remove the redundant ->sock_domain field
6305 - MINOR: protocol: export protocol definitions
6306 - CLEANUP: protocol: group protocol struct members by usage
6307 - MINOR: protocol: add a set of ctrl_init/ctrl_close methods for setup/teardown
6308 - MINOR: connection: use the control layer's init/close
6309 - MINOR: udp: export udp_suspend_receiver() and udp_resume_receiver()
6310 - BUG/MAJOR: spoa/python: Fixing return None
6311 - DOC: spoa/python: Fixing typo in IP related error messages
6312 - DOC: spoa/python: Rephrasing memory related error messages
6313 - DOC: spoa/python: Fixing typos in comments
6314 - BUG/MINOR: spoa/python: Cleanup references for failed Module Addobject operations
6315 - BUG/MINOR: spoa/python: Cleanup ipaddress objects if initialization fails
6316 - BUG/MEDIUM: spoa/python: Fixing PyObject_Call positional arguments
6317 - BUG/MEDIUM: spoa/python: Fixing references to None
6318 - DOC: email change of the DeviceAtlas maintainer
6319 - MINOR: cache: Dump secondary entries in "show cache"
6320 - CLEANUP: connection: use fd_stop_both() instead of conn_stop_polling()
6321 - MINOR: stream-int: don't touch polling anymore on shutdown
6322 - MINOR: connection: implement cs_drain_and_close()
6323 - MINOR: mux-pt: take care of CS_SHR_DRAIN in shutr()
6324 - MINOR: checks: use cs_drain_and_close() instead of draining the connection
6325 - MINOR: checks: don't call conn_cond_update_polling() anymore
6326 - CLEANUP: connection: open-code conn_cond_update_polling() and update the comment
6327 - CLEANUP: connection: remove the unused conn_{stop,cond_update}_polling()
6328 - BUG/MINOR: http-check: Use right condition to consider HTX message as full
6329 - BUG/MINOR: tcpcheck: Don't rearm the check timeout on each read
6330 - MINOR: tcpcheck: Only wait for more payload data on HTTP expect rules
6331 - BUG/MINOR: tools: make parse_time_err() more strict on the timer validity
6332 - BUG/MINOR: tools: Reject size format not starting by a digit
6333 - MINOR: action: define enum for timeout type of the set-timeout rule
6334 - MINOR: stream: prepare the hot refresh of timeouts
6335 - MEDIUM: stream: support a dynamic server timeout
6336 - MEDIUM: stream: support a dynamic tunnel timeout
6337 - MEDIUM: http_act: define set-timeout server/tunnel action
6338 - MINOR: frontend: add client timeout sample fetch
6339 - MINOR: backend: add timeout sample fetches
6340 - MINOR: stream: add sample fetches
6341 - MINOR: stream: add timeout sample fetches
6342 - REGTESTS: add regtest for http-request set-timeout
6343 - CLEANUP: remove the unused fd_stop_send() in conn_xprt_shutw{,_hard}()
6344 - CLEANUP: connection: remove the unneeded fd_stop_{recv,send} on read0/shutw
6345 - MINOR: connection: remove sock-specific code from conn_sock_send()
6346 - REORG: connection: move the socket iocb (conn_fd_handler) to sock.c
6347 - MINOR: protocol: add a ->drain() function at the connection control layer
6348 - MINOR: connection: make conn_sock_drain() use the control layer's ->drain()
6349 - MINOR: protocol: add a pair of check_events/ignore_events functions at the ctrl layer
6350 - MEDIUM: connection: make use of the control layer check_events/ignore_events
6351
Willy Tarreauc94431b2020-12-01 08:15:26 +010063522020/12/01 : 2.4-dev2
6353 - BUILD: Make DEBUG part of .build_opts
6354 - BUILD: Show the value of DEBUG= in haproxy -vv
6355 - CI: Set DEBUG=-DDEBUG_STRICT=1 in GitHub Actions
6356 - MINOR: stream: Add level 7 retries on http error 401, 403
6357 - CLEANUP: remove unused function "ssl_sock_is_ckch_valid"
6358 - BUILD: SSL: add BoringSSL guarding to "RAND_keep_random_devices_open"
6359 - BUILD: SSL: do not "update" BoringSSL version equivalent anymore
6360 - BUG/MEDIUM: http_act: Restore init of log-format list
6361 - DOC: better describes how to configure a fallback crt
6362 - BUG/MAJOR: filters: Always keep all offsets up to date during data filtering
6363 - MINOR: cache: Prepare helper functions for Vary support
6364 - MEDIUM: cache: Add the Vary header support
6365 - MINOR: cache: Add a process-vary option that can enable/disable Vary processing
6366 - BUG/CRITICAL: cache: Fix trivial crash by sending accept-encoding header
6367 - BUG/MAJOR: peers: fix partial message decoding
6368 - DOC: cache: Add new caching limitation information
6369 - DOC: cache: Add information about Vary support
6370 - DOC: better document the config file format and escaping/quoting rules
6371 - DOC: Clarify %HP description in log-format
6372 - CI: github actions: update LibreSSL to 3.3.0
6373 - CI: github actions: enable 51degrees feature
6374 - MINOR: fd/threads: silence a build warning with threads disabled
6375 - BUG/MINOR: tcpcheck: Don't forget to reset tcp-check flags on new kind of check
6376 - MINOR: tcpcheck: Don't handle anymore in-progress send rules in tcpcheck_main
6377 - BUG/MAJOR: tcpcheck: Allocate input and output buffers from the buffer pool
6378 - MINOR: tcpcheck: Don't handle anymore in-progress connect rules in tcpcheck_main
6379 - MINOR: config: Deprecate and ignore tune.chksize global option
6380 - MINOR: config: Add a warning if tune.chksize is used
6381 - REORG: tcpcheck: Move check option parsing functions based on tcp-check
6382 - MINOR: check: Always increment check health counter on CONPASS
6383 - MINOR: tcpcheck: Add support of L7OKC on expect rules error-status argument
6384 - DOC: config: Make disable-on-404 option clearer on transition conditions
6385 - DOC: config: Move req.hdrs and req.hdrs_bin in L7 samples fetches section
6386 - BUG/MINOR: http-fetch: Fix smp_fetch_body() when called from a health-check
6387 - MINOR: plock: use an ARMv8 instruction barrier for the pause instruction
6388 - MINOR: debug: add "debug dev sched" to stress the scheduler.
6389 - MINOR: debug: add a trivial PRNG for scheduler stress-tests
6390 - BUG/MEDIUM: lists: Lock the element while we check if it is in a list.
6391 - MINOR: task: remove tasklet_insert_into_tasklet_list()
6392 - MINOR: task: perform atomic counter increments only once per wakeup
6393 - MINOR: task: remove __tasklet_remove_from_tasklet_list()
6394 - BUG/MEDIUM: task: close a possible data race condition on a tasklet's list link
6395 - BUG/MEDIUM: local log format regression.
6396
Willy Tarreau1a38ffc2020-11-21 16:00:40 +010063972020/11/21 : 2.4-dev1
6398 - MINOR: ist: Add istend() function to return a pointer to the end of the string
6399 - MINOR: sample: Add converters to parse FIX messages
6400 - REGTEST: converter: Add a regtest for fix converters
6401 - MINOR: sample: Add converts to parses MQTT messages
6402 - REGTEST: converter: Add a regtest for MQTT converters
6403 - MINOR: compat: automatically include malloc.h on glibc
6404 - MEDIUM: pools: call malloc_trim() from pool_gc()
6405 - MEDIUM: pattern: call malloc_trim() on pat_ref_reload()
6406 - MINOR: pattern: move the update revision to the pat_ref, not the expression
6407 - CLEANUP: pattern: delete the back refs at once during pat_ref_reload()
6408 - MINOR: pattern: new sflag PAT_SF_REGFREE indicates regex_free() is needed
6409 - MINOR: pattern: make the delete and prune functions more generic
6410 - MEDIUM: pattern: link all final elements from the reference
6411 - MEDIUM: pattern: change the pat_del_* functions to delete from the references
6412 - MINOR: pattern: remerge the list and tree deletion functions
6413 - MINOR: pattern: perform a single call to pat_delete_gen() under the expression
6414 - CLEANUP: acl: don't reference the generic pattern deletion function anymore
6415 - CLEANUP: pattern: remove pat_delete_fcts[] and pattern_head->delete()
6416 - MINOR: pattern: introduce pat_ref_delete_by_ptr() to delete a valid reference
6417 - MINOR: pattern: store a generation number in the reference patterns
6418 - MEDIUM: pattern: only match patterns that match the current generation
6419 - MINOR: pattern: add pat_ref_commit() to commit a previously inserted element
6420 - MINOR: pattern: implement pat_ref_load() to load a pattern at a given generation
6421 - MINOR: pattern: add pat_ref_purge_older() to purge old entries
6422 - MEDIUM: pattern: make pat_ref_prune() rely on pat_ref_purge_older()
6423 - MINOR: pattern: during reload, delete elements frem the ref, not the expression
6424 - MINOR: pattern: prepare removal of a pattern from the list head
6425 - MEDIUM: pattern: turn the pattern chaining to single-linked list
6426 - CLEANUP: cfgparse: remove duplicate registration for transparent build options
6427 - BUG/MINOR: ssl: don't report 1024 bits DH param load error when it's higher
6428 - MINOR: http-htx: Add understandable errors for the errorfiles parsing
6429 - MINOR: ssl: instantiate stats module
6430 - MINOR: ssl: count client hello for stats
6431 - MINOR: ssl: add counters for ssl sessions
6432 - DOC: config: Fix a typo on ssl_c_chain_der
6433 - MINOR: server: remove idle lock in srv_cleanup_connections
6434 - BUILD: ssl: silence build warning on uninitialised counters
6435 - BUILD: http-htx: fix build warning regarding long type in printf
6436 - REGTEST: ssl: test wildcard and multi-type + exclusions
6437 - BUG/MEDIUM: ssl/crt-list: correctly insert crt-list line if crt already loaded
6438 - CI: Expand use of GitHub Actions for CI
6439 - REGTEST: ssl: mark reg-tests/ssl/ssl_crt-list_filters.vtc as broken
6440 - BUG/MINOR: pattern: a sample marked as const could be written
6441 - BUG/MINOR: lua: set buffer size during map lookups
6442 - MEDIUM: cache: Change caching conditions
6443 - BUG/MINOR: stats: free dynamically stats fields/lines on shutdown
6444 - BUG/MEDIUM: stats: prevent crash if counters not alloc with dummy one
6445 - MINOR: peers: Add traces to peer_treat_updatemsg().
6446 - BUG/MINOR: peers: Do not ignore a protocol error for dictionary entries.
6447 - BUG/MINOR: peers: Missing TX cache entries reset.
6448 - BUG/MEDIUM: peers: fix decoding of multi-byte length in stick-table messages
6449 - BUG/MINOR: http-fetch: Extract cookie value even when no cookie name
6450 - BUG/MINOR: http-fetch: Fix calls w/o parentheses of the cookie sample fetches
6451 - BUG/MEDIUM: check: reuse srv proto only if using same mode
6452 - MINOR: check: report error on incompatible proto
6453 - MINOR: check: report error on incompatible connect proto
6454 - BUG/MINOR: http-htx: Handle warnings when parsing http-error and http-errors
6455 - BUG/MAJOR: spoe: Be sure to remove all references on a released spoe applet
6456 - MINOR: spoe: Don't close connection in sync mode on processing timeout
6457 - BUG/MINOR: tcpcheck: Don't warn on unused rules if check option is after
6458 - MINOR: init: Fix the prototype for per-thread free callbacks
6459 - MINOR: config/mux-h2: Return ERR_ flags from init_h2() instead of a status
6460 - CLEANUP: config: Return ERR_NONE from config callbacks instead of 0
6461 - MINOR: cfgparse: tighten the scope of newnameserver variable, free it on error.
6462 - REGTEST: make ssl_client_samples and ssl_server_samples require to 2.2
6463 - REGTESTS: Add sample_fetches/cook.vtc
6464 - BUG/MEDIUM: filters: Forward all filtered data at the end of http filtering
6465 - BUG/MINOR: http-ana: Don't wait for the body of CONNECT requests
6466 - CLEANUP: flt-trace: Remove unused random-parsing option
6467 - MINOR: flt-trace: Add an option to inhibits trace messages
6468 - MINOR: flt-trace: Use a bitfield for the trace options
6469 - REGTESTS: Add a script to test the random forwarding with several filters
6470 - REGTESTS: mark the abns test as broken again
6471 - REGTESTS: converter: add url_dec test
6472 - CI: Stop hijacking the hosts file
6473 - CI: Make the h2spec workflow more consistent with the VTest workflow
6474 - CI: travis-ci: remove amd64, osx builds
6475 - CI: travis-ci: arm64 are not allowed to fail anymore
6476 - DOC: add missing 3.10 in the summary
6477 - MINOR: ssl: remove client hello counters
6478 - MEDIUM: stats: add counters for failed handshake
6479 - MINOR: ssl: create common ssl_ctx init
6480 - MEDIUM: cli/ssl: configure ssl on server at runtime
6481 - REGTEST: server/cli_set_ssl.vtc requires OpenSSL
6482 - DOC: coding-style: update a few rules about pointers
6483 - BUG/MINOR: ssl: segv on startup when AKID but no keyid
6484 - BUILD: ssl: use SSL_MODE_ASYNC macro instead of OPENSSL_VERSION
6485 - BUG/MEDIUM: http-ana: Don't eval http-after-response ruleset on empty messages
6486 - BUG/MEDIUM: ssl/crt-list: bundle support broken in crt-list
6487 - BUG/MEDIUM: ssl: error when no certificate are found
6488 - BUG/MINOR: ssl/crt-list: load bundle in crt-list only if activated
6489 - BUG/MEDIUM: ssl/crt-list: fix error when no file found
6490 - CI: Github Actions: enable prometheus exporter
6491 - CI: Github Actions: remove LibreSSL-3.0.2 builds
6492 - CI: Github Actions: enable BoringSSL builds
6493 - CI: travis-ci: remove builds migrated to GH actions
6494 - BUILD: makefile: enable crypt(3) for OpenBSD
6495 - CI: Github Action: run "apt-get update" before packages restore
6496 - BUILD: SSL: guard TLS13 ciphersuites with HAVE_SSL_CTX_SET_CIPHERSUITES
6497 - CI: Pass the github.event_name to matrix.py
6498 - CI: Clean up Windows CI
6499 - DOC: clarify how to create a fallback crt
6500 - CLEANUP: connection: do not use conn->owner when the session is known
6501 - BUG/MAJOR: connection: reset conn->owner when detaching from session list
6502 - REGTESTS: mark proxy_protocol_random_fail as broken
6503 - BUG/MINOR: http_htx: Fix searching headers by substring
6504 - MINOR: http_act: Add -m flag for del-header name matching method
6505
Willy Tarreau1db55792020-11-05 17:20:35 +010065062020/11/05 : 2.4-dev0
6507 - MINOR: version: it's development again.
6508 - DOC: mention in INSTALL that it's development again
6509
Willy Tarreau1c0a7222020-11-05 17:04:53 +010065102020/11/05 : 2.3.0
6511 - CLEANUP: pattern: remove unused entry "tree" in pattern.val
6512 - BUILD: ssl: use SSL_CTRL_GET_RAW_CIPHERLIST instead of OpenSSL versions
6513 - BUG/MEDIUM: filters: Don't try to init filters for disabled proxies
6514 - BUG/MINOR: proxy/server: Skip per-proxy/server post-check for disabled proxies
6515 - BUG/MINOR: checks: Report a socket error before any connection attempt
6516 - BUG/MINOR: server: Set server without addr but with dns in RMAINT on startup
6517 - MINOR: server: Copy configuration file and line for server templates
6518 - BUG/MEDIUM: mux-pt: Release the tasklet during an HTTP upgrade
6519 - BUILD: ssl: use HAVE_OPENSSL_KEYLOG instead of OpenSSL versions
6520 - MINOR: debug: don't count free(NULL) in memstats
6521 - BUG/MINOR: filters: Skip disabled proxies during startup only
6522 - MINOR: mux_h2: capitalize frame type in stats
6523 - MINOR: mux_h2: add stat for total count of connections/streams
6524 - MINOR: stats: do not display empty stat module title on html
6525 - BUG/MEDIUM: stick-table: limit the time spent purging old entries
6526 - BUG/MEDIUM: listener: only enable a listening listener if needed
6527 - BUG/MEDIUM: listener: never suspend inherited sockets
6528 - BUG/MEDIUM: listener: make the master also keep workers' inherited FDs
6529 - MINOR: fd: add fd_want_recv_safe()
6530 - MEDIUM: listeners: make use of fd_want_recv_safe() to enable early receivers
6531 - REGTESTS: mark abns_socket as working now
6532 - CLEANUP: mux-h2: Remove the h1 parser state from the h2 stream
6533 - MINOR: sock: add a check against cross worker<->master socket activities
6534 - CI: github actions: limit OpenSSL no-deprecated builds to "default,bug,devel" reg-tests
6535 - BUG/MEDIUM: server: make it possible to kill last idle connections
6536 - MINOR: mworker/cli: the master CLI use its own applet
6537 - MINOR: ssl: define SSL_CTX_set1_curves_list to itself on BoringSSL
6538 - BUILD: ssl: use feature macros for detecting ec curves manipulation support
6539 - DOC: Add dns as an available domain to show stat
6540 - BUILD: makefile: usual reorder of objects for faster builds
6541 - DOC: update INSTALL to mention that TCC is supported
6542 - DOC: mention in INSTALL that haproxy 2.3 is a stable version
6543 - MINOR: version: mention that it's stable now
6544
Willy Tarreaubd703e52020-10-31 13:17:06 +010065452020/10/31 : 2.3-dev9
6546 - CLEANUP: http_ana: remove unused assignation of `att_beg`
6547 - BUG/MEDIUM: ssl: OCSP must work with BoringSSL
6548 - BUG/MINOR: log: fix memory leak on logsrv parse error
6549 - BUG/MINOR: log: fix risk of null deref on error path
6550 - BUILD: ssl: more elegant OpenSSL early data support check
6551 - CI: github actions: update h2spec to 2.6.0
6552 - BUG/MINOR: cache: Check the return value of http_replace_res_status
6553 - MINOR: cache: Store the "Last-Modified" date in the cache_entry
6554 - MINOR: cache: Process the If-Modified-Since header in conditional requests
6555 - MINOR: cache: Create res.cache_hit and res.cache_name sample fetches
6556 - MINOR: mux-h2: register a stats module
6557 - MINOR: mux-h2: add counters instance to h2c
6558 - MINOR: mux-h2: add stats for received frame types
6559 - MINOR: mux-h2: report detected error on stats
6560 - MINOR: mux-h2: count open connections/streams on stats
6561 - BUG/MINOR: server: fix srv downtime calcul on starting
6562 - BUG/MINOR: server: fix down_time report for stats
6563 - BUG/MINOR: lua: initialize sample before using it
6564 - MINOR: cache: Add Expires header value parsing
6565 - MINOR: ist: Add a case insensitive istmatch function
6566 - BUG/MINOR: cache: Manage multiple values in cache-control header value
6567 - BUG/MINOR: cache: Inverted variables in http_calc_maxage function
6568 - MINOR: pattern: make pat_ref_append() return the newly added element
6569 - MINOR: pattern: make pat_ref_add() rely on pat_ref_append()
6570 - MINOR: pattern: export pat_ref_push()
6571 - CLEANUP: pattern: use calloc() rather than malloc for structures
6572 - CLEANUP: pattern: fix spelling/grammatical/copy-paste in comments
6573
Willy Tarreaufb1b9e32020-10-24 13:14:31 +020065742020/10/24 : 2.3-dev8
6575 - MINOR: backend: replace the lbprm lock with an rwlock
6576 - MINOR: lb/map: use seek lock and read locks where appropriate
6577 - MINOR: lb/leastconn: only take a read lock in fwlc_get_next_server()
6578 - MINOR: lb/first: use a read lock in fas_get_next_server()
6579 - MINOR: lb/chash: use a read lock in chash_get_server_hash()
6580 - BUG/MINOR: disable dynamic OCSP load with BoringSSL
6581 - BUILD: ssl: make BoringSSL use its own version numbers
6582 - CLEANUP: threads: don't register an initcall when not debugging
6583 - MINOR: threads: change lock_t to an unsigned int
6584 - CLEANUP: tree-wide: reorder a few structures to plug some holes around locks
6585 - CLEANUP: task: remove the unused and mishandled global_rqueue_size
6586 - BUG/MEDIUM: connection: Never cleanup server lists when freeing private conns
6587 - MEDIUM: config: report that "nbproc" is deprecated
6588 - BUG/MINOR: listener: close before free in `listener_accept`
6589 - MINOR: ssl: 'ssl-load-extra-del-ext' removes the certificate extension
6590 - BUG/MINOR: queue: properly report redistributed connections
6591 - CONTRIB: tcploop: remove unused local variables in tcp_pause()
6592 - BUILD: makefile: add entries to build common debugging tools
6593 - BUG/MEDIUM: server: support changing the slowstart value from state-file
6594 - MINOR: http: Add `enum etag_type http_get_etag_type(const struct ist)`
6595 - MINOR: http: Add etag comparison function
6596 - MEDIUM: cache: Store the ETag information in the cache_entry
6597 - MEDIUM: cache: Add support for 'If-None-Match' request header
6598 - REGTEST: cache: Add if-none-match test case
6599 - CLEANUP: compression: Make use of http_get_etag_type()
6600 - BUG/MINOR: http-ana: Don't send payload for internal responses to HEAD requests
6601 - BUG/MAJOR: mux-h2: Don't try to send data if we know it is no longer possible
6602 - MINOR: threads/debug: only report used lock stats
6603 - MINOR: threads/debug: only report lock stats for used operations
6604 - MINOR: proxy; replace the spinlock with an rwlock
6605 - MINOR: server: read-lock the cookie during srv_set_dyncookie()
6606 - MINOR: proxy/cli: only take a read lock in "show errors"
6607 - OPTIM: queue: don't call pendconn_unlink() when the pendconn is not queued
6608 - MINOR: queue: split __pendconn_unlink() in per-srv and per-prx
6609 - MINOR: queue: reduce the locked area in pendconn_add()
6610 - OPTIM: queue: make the nbpend counters atomic
6611 - OPTIM: queue: decrement the nbpend and totpend counters outside of the lock
6612 - MINOR: leastconn: take the queue length into account when queuing servers
6613 - MEDIUM: fwlc: re-enable per-server queuing up to maxqueue
6614 - Revert "OPTIM: queue: don't call pendconn_unlink() when the pendconn is not queued"
6615 - MINOR: stats: support the "up" output modifier for "show stat"
6616 - MINOR: stats: also support a "no-maint" show stat modifier
6617 - MINOR: stats: indicate the number of servers in a backend's status
6618 - MEDIUM: ssl: ssl-load-extra-del-ext work only with .crt
6619 - REGTEST: ssl: test "set ssl cert" with separate key / crt
6620 - DOC: management: apply the "show stat" modifiers to "show stat", not "show info"
6621 - MINOR: stats: report server's user-configured weight next to effective weight
6622 - CI: travis-ci: switch to Ubuntu 20.04
6623 - CONTRIB: release-estimator: Add release estimating tool
6624 - BUG/MEDIUM: queue: fix unsafe proxy pointer when counting nbpend
6625 - BUG/MINOR: extcheck: add missing checks on extchk_setenv()
6626
Willy Tarreau9d58c9b2020-10-17 10:31:50 +020066272020/10/17 : 2.3-dev7
6628 - CI: travis-ci: replace not defined SSL_LIB, SSL_INC for BotringSSL builds
6629 - BUG/MINOR: init: only keep rlim_fd_cur if max is unlimited
6630 - BUG/MINOR: mux-h2: do not stop outgoing connections on stopping
6631 - MINOR: fd: report an error message when failing initial allocations
6632 - MINOR: proto-tcp: make use of connect(AF_UNSPEC) for the pause
6633 - MINOR: sock: add sock_accept_conn() to test a listening socket
6634 - MINOR: protocol: make proto_tcp & proto_uxst report listening sockets
6635 - MINOR: sockpair: implement the .rx_listening function
6636 - CLEANUP: tcp: make use of sock_accept_conn() where relevant
6637 - CLEANUP: unix: make use of sock_accept_conn() where relevant
6638 - BUG/MINOR: listener: detect and handle shared sockets stopped in other processes
6639 - CONTRIB: tcploop: implement a disconnect operation 'D'
6640 - CLEANUP: protocol: intitialize all of the sockaddr when disconnecting
6641 - BUG/MEDIUM: deinit: check fdtab before fdtab[fd].owner
6642 - BUG/MINOR: connection: fix loop iter on connection takeover
6643 - BUG/MEDIUM: connection: fix srv idle count on conn takeover
6644 - MINOR: connection: improve list api usage
6645 - MINOR: mux/connection: add a new mux flag for HOL risk
6646 - MINOR: connection: don't check priv flag on free
6647 - MEDIUM: backend: add new conn to session if mux marked as HOL blocking
6648 - MEDIUM: backend: add reused conn to sess if mux marked as HOL blocking
6649 - MEDIUM: h2: remove conn from session on detach
6650 - MEDIUM: fcgi: remove conn from session on detach
6651 - DOC: Describe reuse safe for HOL handling
6652 - MEDIUM: proxy: remove obsolete "mode health"
6653 - MEDIUM: proxy: remove obsolete "monitor-net"
6654 - CLEANUP: protocol: remove the ->drain() function
6655 - CLEANUP: fd: finally get rid of fd_done_recv()
6656 - MINOR: connection: make sockaddr_alloc() take the address to be copied
6657 - MEDIUM: listener: allocate the connection before queuing a new connection
6658 - MINOR: session: simplify error path in session_accept_fd()
6659 - MINOR: connection: add new error codes for accept_conn()
6660 - MINOR: sock: rename sock_accept_conn() to sock_accepting_conn()
6661 - MINOR: protocol: add a new function accept_conn()
6662 - MINOR: sock: implement sock_accept_conn() to accept a connection
6663 - MINOR: sockpair: implement sockpair_accept_conn() to accept a connection
6664 - MEDIUM: listener: use protocol->accept_conn() to accept a connection
6665 - MEDIUM: listener: remove the second pass of fd manipulation at the end
6666 - MINOR: protocol: add a default I/O callback and put it into the receiver
6667 - MINOR: log: set the UDP receiver's I/O handler in the receiver
6668 - MINOR: protocol: register the receiver's I/O handler and not the protocol's
6669 - CLEANUP: protocol: remove the now unused <handler> field of proto_fam->bind()
6670 - DOC: improve the documentation for "option nolinger"
6671 - BUG/MEDIUM: proxy: properly stop backends
6672 - BUG/MEDIUM: task: bound the number of tasks picked from the wait queue at once
6673 - MINOR: threads: augment rwlock debugging stats to report seek lock stats
6674 - MINOR: threads: add the transitions to/from the seek state
6675 - MEDIUM: task: use an upgradable seek lock when scanning the wait queue
6676 - BUILD: listener: avoir a build warning when threads are disabled
6677 - BUG/MINOR: peers: Possible unexpected peer seesion reset after collisions.
6678 - MINOR: ssl: add volatile flags to ssl samples
6679 - MEDIUM: backend: reuse connection if using a static sni
6680 - BUG/MEDIUM: spoe: Unset variable instead of set it if no data provided
6681 - BUG/MEDIUM: mux-h1: Get the session from the H1S when capturing bad messages
6682 - BUG/MEDIUM: lb: Always lock the server when calling server_{take,drop}_conn
6683 - DOC: fix typo in MAX_SESS_STKCTR
6684
Willy Tarreaub7ffe192020-10-10 10:45:13 +020066852020/10/10 : 2.3-dev6
6686 - REGTESTS: use "command" instead of "which" for better POSIX compatibility
6687 - BUILD: makefile: Update feature flags for OpenBSD
6688 - DOC: agent-check: fix typo in "fail" word expected reply
6689 - DOC: crt: advise to move away from cert bundle
6690 - BUG/MINOR: ssl/crt-list: exit on warning out of crtlist_parse_line()
6691 - REGTEST: fix host part in balance-uri-path-only.vtc
6692 - REGTEST: make ssl_client_samples and ssl_server_samples requiret to 2.3
6693 - REGTEST: the iif converter test requires 2.3
6694 - REGTEST: make agent-check.vtc require 1.8
6695 - REGTEST: make abns_socket.vtc require 1.8
6696 - REGTEST: make map_regm_with_backref require 1.7
6697 - BUILD: makefile: Update feature flags for FreeBSD
6698 - OPTIM: backend/random: never queue on the server, always on the backend
6699 - OPTIM: backend: skip LB when we know the backend is full
6700 - BUILD: makefile: Fix building with closefrom() support enabled
6701 - BUILD: makefile: add an EXTRAVERSION variable to ease local naming
6702 - MINOR: tools: support for word expansion of environment in parse_line
6703 - BUILD: tools: fix minor build issue on isspace()
6704 - BUILD: makefile: Enable closefrom() support on Solaris
6705 - CLEANUP: ssl: Use structured format for error line report during crt-list parsing
6706 - MINOR: ssl: Add error if a crt-list might be truncated
6707 - MINOR: ssl: remove uneeded check in crtlist_parse_file
6708 - BUG/MINOR: Fix several leaks of 'log_tag' in init().
6709 - DOC: tcp-rules: Refresh details about L7 matching for tcp-request content rules
6710 - MEDIUM: tcp-rules: Warn if a track-sc* content rule doesn't depend on content
6711 - BUG/MINOR: tcpcheck: Set socks4 and send-proxy flags before the connect call
6712 - DOC: ssl: new "cert bundle" behavior
6713 - BUG/MEDIUM: queue: make pendconn_cond_unlink() really thread-safe
6714 - CLEANUP: ssl: "bundle" is not an OpenSSL wording
6715 - MINOR: counters: fix a typo in comment
6716 - BUG/MINOR: stats: fix validity of the json schema
6717 - REORG: stats: export some functions
6718 - MINOR: stats: add stats size as a parameter for csv/json dump
6719 - MINOR: stats: hide px/sv/li fields in applet struct
6720 - REORG: stats: extract proxy json dump
6721 - REORG: stats: extract proxies dump loop in a function
6722 - MINOR: hlua: Display debug messages on stderr only in debug mode
6723 - MINOR: stats: define the concept of domain for statistics
6724 - MINOR: stats: define additional flag px cap on domain
6725 - MEDIUM: stats: add delimiter for static proxy stats on csv
6726 - MEDIUM: stats: define an API to register stat modules
6727 - MEDIUM: stats: add abstract type to store counters
6728 - MEDIUM: stats: integrate static proxies stats in new stats
6729 - MINOR: stats: support clear counters for dynamic stats
6730 - MINOR: stats: display extra proxy stats on the html page
6731 - MINOR: stats: add config "stats show modules"
6732 - MINOR: dns/stats: integrate dns counters in stats
6733 - MINOR: stats: remove for loop declaration
6734 - DOC: ssl: fix typo about ocsp files
6735 - BUG/MINOR: peers: Inconsistency when dumping peer status codes.
6736 - DOC: update INSTALL with supported OpenBSD / FreeBSD versions
6737 - BUG/MINOR: proto_tcp: Report warning messages when listeners are bound
6738 - CLEANUP: cache: Fix leak of cconf->c.name during config check
6739 - CLEANUP: ssl: Release cached SSL sessions on deinit
6740 - BUG/MINOR: mux-h1: Be sure to only set CO_RFL_READ_ONCE for the first read
6741 - BUG/MINOR: mux-h1: Always set the session on frontend h1 stream
6742 - MINOR: mux-h1: Don't wakeup the H1C when output buffer become available
6743 - CLEANUP: sock-unix: Remove an unreachable goto clause
6744 - BUG/MINOR: proxy: inc req counter on new syslog messages.
6745 - BUG/MEDIUM: log: old processes with log foward section don't die on soft stop.
6746 - MINOR: stats: inc req counter on listeners.
6747 - MINOR: channel: new getword and getchar functions on channel.
6748 - MEDIUM: log: syslog TCP support on log forward section.
6749 - BUG/MINOR: proxy/log: frontend/backend and log forward names must differ
6750 - DOC: re-work log forward bind statement documentation.
6751 - DOC: fix a confusing typo on a regsub example
6752 - BUILD: Add a DragonFlyBSD target
6753 - BUG/MINOR: makefile: fix a tiny typo in the target list
6754 - BUILD: makefile: Update feature flags for NetBSD
6755 - CI: travis-ci: help Coverity to detect BUG_ON() as a real stop
6756 - DOC: Add missing stats fields in the management doc
6757 - BUG/MEDIUM: mux-fcgi: Don't handle pending read0 too early on streams
6758 - BUG/MEDIUM: mux-h2: Don't handle pending read0 too early on streams
6759 - DOC: Fix typos in configuration.txt
6760 - BUG/MINOR: http: Fix content-length of the default 500 error
6761 - BUG/MINOR: http-htx: Expect no body for 204/304 internal HTTP responses
6762 - REGTESTS: mark abns_socket as broken
6763 - MEDIUM: fd: always wake up one thread when enabling a foreing FD
6764 - MEDIUM: listeners: don't bounce listeners management between queues
6765 - MEDIUM: init: stop disabled proxies after initializing fdtab
6766 - MEDIUM: listeners: make unbind_listener() converge if needed
6767 - MEDIUM: deinit: close all receivers/listeners before scanning proxies
6768 - MEDIUM: listeners: remove the now unused ZOMBIE state
6769 - MINOR: listeners: do not uselessly try to close zombie listeners in soft_stop()
6770 - CLEANUP: proxy: remove the first_to_listen hack in zombify_proxy()
6771 - MINOR: listeners: introduce listener_set_state()
6772 - MINOR: proxy: maintain per-state counters of listeners
6773 - MEDIUM: proxy: remove the unused PR_STFULL state
6774 - MEDIUM: proxy: remove the PR_STERROR state
6775 - MEDIUM: proxy: remove state PR_STPAUSED
6776 - MINOR: startup: don't rely on PR_STNEW to check for listeners
6777 - CLEANUP: peers: don't use the PR_ST* states to mark enabled/disabled
6778 - MEDIUM: proxy: replace proxy->state with proxy->disabled
6779 - MEDIUM: proxy: remove start_proxies()
6780 - MEDIUM: proxy: merge zombify_proxy() with stop_proxy()
6781 - MINOR: listeners: check the current listener state in pause_listener()
6782 - MINOR: listeners: check the current listener earlier state in resume_listener()
6783 - MEDIUM: listener/proxy: make the listeners notify about proxy pause/resume
6784 - MINOR: protocol: introduce protocol_{pause,resume}_all()
6785 - MAJOR: signals: use protocol_pause_all() and protocol_resume_all()
6786 - CLEANUP: proxy: remove the now unused pause_proxies() and resume_proxies()
6787 - MEDIUM: proto_tcp: make the pause() more robust in multi-process
6788 - BUG/MEDIUM: listeners: correctly report pause() errors
6789 - MINOR: listeners: move fd_stop_recv() to the receiver's socket code
6790 - CLEANUP: protocol: remove the ->disable_all method
6791 - CLEANUP: listeners: remove unused disable_listener and disable_all_listeners
6792 - MINOR: listeners: export enable_listener()
6793 - MINOR: protocol: directly call enable_listener() from protocol_enable_all()
6794 - CLEANUP: protocol: remove the ->enable_all method
6795 - CLEANUP: listeners: remove the now unused enable_all_listeners()
6796 - MINOR: protocol: rename the ->listeners field to ->receivers
6797 - MINOR: protocol: replace ->pause(listener) with ->rx_suspend(receiver)
6798 - MINOR: protocol: implement an ->rx_resume() method
6799 - MINOR: listener: use the protocol's ->rx_resume() method when available
6800 - MINOR: sock: provide a set of generic enable/disable functions
6801 - MINOR: protocol: add a new pair of rx_enable/rx_disable methods
6802 - MINOR: protocol: add a new pair of enable/disable methods for listeners
6803 - MEDIUM: listeners: now use the listener's ->enable/disable
6804 - MINOR: listeners: split delete_listener() in two versions
6805 - MINOR: listeners: count unstoppable jobs on creation, not deletion
6806 - MINOR: listeners: add a new stop_listener() function
6807 - MEDIUM: proxy: make stop_proxy() now use stop_listener()
6808 - MEDIUM: proxy: add mode PR_MODE_PEERS to flag peers frontends
6809 - MEDIUM: proxy: centralize proxy status update and reporting
6810 - MINOR: protocol: add protocol_stop_now() to instant-stop listeners
6811 - MEDIUM: proxy: make soft_stop() stop most listeners using protocol_stop_now()
6812 - MEDIUM: udp: implement udp_suspend() and udp_resume()
6813 - MINOR: listener: add a few BUG_ON() statements to detect inconsistencies
6814 - MEDIUM: listeners: always close master vs worker listeners
6815 - BROKEN/MEDIUM: listeners: rework the unbind logic to make it idempotent
6816 - MEDIUM: listener: let do_unbind_listener() decide whether to close or not
6817 - CLEANUP: listeners: remove the do_close argument to unbind_listener()
6818 - MINOR: listeners: move the LI_O_MWORKER flag to the receiver
6819 - MEDIUM: receivers: add an rx_unbind() method in the protocols
6820 - MINOR: listeners: split do_unbind_listener() in two
6821 - MEDIUM: listeners: implement protocol level ->suspend/resume() calls
6822 - MEDIUM: config: mark "grace" as deprecated
6823 - MEDIUM: config: remove the deprecated and dangerous global "debug" directive
6824 - BUG/MINOR: proxy: respect the proper format string in sig_pause/sig_listen
6825 - MINOR: peers: heartbeat, collisions and handshake information for "show peers" command.
6826 - BUILD: makefile: Enable getaddrinfo() on OS/X
6827
Christopher Faulet05f01882020-09-25 18:40:47 +020068282020/09/25 : 2.3-dev5
6829 - DOC: Fix typo in iif() example
6830 - CLEANUP: Update .gitignore
6831 - BUILD: introduce possibility to define ABORT_NOW() conditionally
6832 - CI: travis-ci: help Coverity to recognize abort()
6833 - BUG/MINOR: Fix type passed of sizeof() for calloc()
6834 - CLEANUP: Do not use a fixed type for 'sizeof' in 'calloc'
6835 - CLEANUP: tree-wide: use VAR_ARRAY instead of [0] in various definitions
6836 - BUILD: connection: fix build on clang after the VAR_ARRAY cleanup
6837 - BUG/MINOR: ssl: verifyhost is case sensitive
6838 - BUILD: makefile: change default value of CC from gcc to cc
6839 - CI: travis-ci: split asan step out of running tests
6840 - BUG/MINOR: server: report correct error message for invalid port on "socks4"
6841 - BUG/MEDIUM: ssl: Don't call ssl_sock_io_cb() directly.
6842 - BUG/MINOR: ssl/crt-list: crt-list could end without a \n
6843 - BUG/MINOR: log-forward: fail on unknown keywords
6844 - MEDIUM: log-forward: use "dgram-bind" instead of "bind" for the listener
6845 - BUG/MEDIUM: log-forward: always quit on parsing errors
6846 - MEDIUM: ssl: remove bundle support in crt-list and directories
6847 - MEDIUM: ssl/cli: remove support for multi certificates bundle
6848 - MINOR: ssl: crtlist_dup_ssl_conf() duplicates a ssl_bind_conf
6849 - MINOR: ssl: crtlist_entry_dup() duplicates a crtlist_entry
6850 - MEDIUM: ssl: emulates the multi-cert bundles in the crtlist
6851 - MEDIUM: ssl: emulate multi-cert bundles loading in standard loading
6852 - CLEANUP: ssl: remove test on "multi" variable in ckch functions
6853 - CLEANUP: ssl/cli: remove test on 'multi' variable in CLI functions
6854 - CLEANUP: ssl: remove utility functions for bundle
6855 - DOC: explain bundle emulation in configuration.txt
6856 - BUILD: fix build with openssl < 1.0.2 since bundle removal
6857 - BUG/MINOR: log: gracefully handle the "udp@" address format for log servers
6858 - BUG/MINOR: dns: gracefully handle the "udp@" address format for nameservers
6859 - MINOR: listener: create a new struct "settings" in bind_conf
6860 - MINOR: listener: move bind_proc and bind_thread to struct settings
6861 - MINOR: listener: move the interface to the struct settings
6862 - MINOR: listener: move the network namespace to the struct settings
6863 - REORG: listener: create a new struct receiver
6864 - REORG: listener: move the listening address to a struct receiver
6865 - REORG: listener: move the receiving FD to struct receiver
6866 - REORG: listener: move the listener's proto to the receiver
6867 - MINOR: listener: make sock_find_compatible_fd() check the socket type
6868 - REORG: listener: move the receiver part to a new file
6869 - MINOR: receiver: link the receiver to its settings
6870 - MINOR: receiver: link the receiver to its owner
6871 - MINOR: listener: prefer to retrieve the socket's settings via the receiver
6872 - MINOR: receiver: add a receiver-specific flag to indicate the socket is bound
6873 - MINOR: listener: move the INHERITED flag down to the receiver
6874 - MINOR: receiver: move the FOREIGN and V6ONLY options from listener to settings
6875 - MINOR: sock: make sock_find_compatible_fd() only take a receiver
6876 - MINOR: protocol: rename the ->bind field to ->listen
6877 - MINOR: protocol: add a new ->bind() entry to bind the receiver
6878 - MEDIUM: sock_inet: implement sock_inet_bind_receiver()
6879 - MEDIUM: tcp: make use of sock_inet_bind_receiver()
6880 - MEDIUM: udp: make use of sock_inet_bind_receiver()
6881 - MEDIUM: sock_unix: implement sock_unix_bind_receiver()
6882 - MEDIUM: uxst: make use of sock_unix_bind_receiver()
6883 - MEDIUM: sockpair: implement sockpair_bind_receiver()
6884 - MEDIUM: proto_sockpair: make use of sockpair_bind_receiver()
6885 - MEDIUM: protocol: explicitly start the receiver before the listener
6886 - MEDIUM: protocol: do not call proto->bind() anymore from bind_listener()
6887 - MINOR: protocol: add a new proto_fam structure for protocol families
6888 - MINOR: protocol: retrieve the family-specific fields from the family
6889 - CLEANUP: protocol: remove family-specific fields from struct protocol
6890 - MINOR: protocol: add a real family for existing FDs
6891 - CLEANUP: tools: make str2sa_range() less awful for fd@ and sockpair@
6892 - MINOR: tools: make str2sa_range() take more options than just resolve
6893 - MINOR: tools: add several PA_O_PORT_* flags in str2sa_range() callers
6894 - MEDIUM: tools: make str2sa_range() validate callers' port specifications
6895 - MEDIUM: config: remove all checks for missing/invalid ports/ranges
6896 - MINOR: tools: add several PA_O_* flags in str2sa_range() callers
6897 - MINOR: listener: remove the inherited arg to create_listener()
6898 - MINOR: tools: make str2sa_range() optionally return the fd
6899 - MINOR: log: detect LOG_TARGET_FD from the fd and not from the syntax
6900 - MEDIUM: tools: make str2sa_range() resolve pre-bound listeners
6901 - MINOR: config: do not test an inherited socket again
6902 - MEDIUM: tools: make str2sa_range() check for the sockpair's FD usability
6903 - MINOR: tools: start to distinguish stream and dgram in str2sa_range()
6904 - MEDIUM: tools: make str2sa_range() only report AF_CUST_UDP on listeners
6905 - MINOR: tools: remove the central test for "udp" in str2sa_range()
6906 - MINOR: cfgparse: add str2receiver() to parse dgram receivers
6907 - MINOR: log-forward: use str2receiver() to parse the dgram-bind address
6908 - MEDIUM: config: make str2listener() not accept datagram sockets anymore
6909 - MINOR: listener: pass the chosen protocol to create_listeners()
6910 - MINOR: tools: make str2sa_range() directly return the protocol
6911 - MEDIUM: tools: make str2sa_range() check that the protocol has ->connect()
6912 - MINOR: protocol: add the control layer type in the protocol struct
6913 - MEDIUM: protocol: store the socket and control type in the protocol array
6914 - MEDIUM: tools: make str2sa_range() use protocol_lookup()
6915 - MEDIUM: proto_udp: replace last AF_CUST_UDP* with AF_INET*
6916 - MINOR: tools: drop listener detection hack from str2sa_range()
6917 - BUILD: sock_unix: add missing errno.h
6918 - MINOR: sock_inet: report the errno string in binding errors
6919 - MINOR: sock_unix: report the errno string in binding errors
6920 - BUILD: sock_inet: include errno.h
6921 - MINOR: h2/trace: also display the remaining frame length in traces
6922 - BUG/MINOR: h2/trace: do not display "stream error" after a frame ACK
6923 - BUG/MEDIUM: h2: report frame bits only for handled types
6924 - BUG/MINOR: http-fetch: Don't set the sample type during the htx prefetch
6925 - BUG/MINOR: Fix memory leaks cfg_parse_peers
6926 - BUG/MINOR: config: Fix memory leak on config parse listen
6927 - MINOR: backend: make the "whole" option of balance uri take only one bit
6928 - MINOR: backend: add a new "path-only" option to "balance uri"
6929 - REGTESTS: add a few load balancing tests
6930 - BUG/MEDIUM: listeners: do not pause foreign listeners
6931 - BUG/MINOR: listeners: properly close listener FDs
6932 - BUILD: trace: include tools.h
6933
Willy Tarreau253c4dc2020-09-11 17:05:59 +020069342020/09/11 : 2.3-dev4
6935 - MINOR: hlua: Add error message relative to the Channel manipulation and HTTP mode
6936 - BUG/MEDIUM: ssl: crt-list negative filters don't work
6937 - DOC: overhauling github issue templates
6938 - MEDIUM: cfgparse: Emit hard error on truncated lines
6939 - DOC: cache: Use '<name>' instead of '<id>' in error message
6940 - MINOR: cache: Reject duplicate cache names
6941 - REGTEST: remove stray leading spaces in converteers_ref_cnt_never_dec.vtc
6942 - MINOR: stats: prevent favicon.ico requests for stats page
6943 - BUILD: tools: include auxv a bit later
6944 - BUILD: task: work around a bogus warning in gcc 4.7/4.8 at -O1
6945 - MEDIUM: ssl: Support certificate chaining for certificate generation
6946 - MINOR: ssl: Support SAN extension for certificate generation
6947 - MINOR: tcp: don't try to set/clear v6only on inherited sockets
6948 - BUG/MINOR: reload: detect the OS's v6only status before choosing an old socket
6949 - MINOR: reload: determine the foreing binding status from the socket
6950 - MEDIUM: reload: stop passing listener options along with FDs
6951 - BUG/MEDIUM: ssl: fix ssl_bind_conf double free w/ wildcards
6952 - MEDIUM: fd: replace usages of fd_remove() with fd_stop_both()
6953 - CLEANUP: fd: remove fd_remove() and rename fd_dodelete() to fd_delete()
6954 - MINOR: fd: add a new "exported" flag and use it for all regular listeners
6955 - MEDIUM: reload: pass all exportable FDs, not just listeners
6956 - DOC: add description of pidfile in master-worker mode
6957 - BUG/MINOR: reload: do not fail when no socket is sent
6958 - REORG: tcp: move TCP actions from proto_tcp.c to tcp_act.c
6959 - CLEANUP: tcp: stop exporting smp_fetch_src()
6960 - REORG: tcp: move TCP sample fetches from proto_tcp.c to tcp_sample.c
6961 - REORG: tcp: move TCP bind/server keywords from proto_tcp.c to cfgparse-tcp.c
6962 - REORG: unix: move UNIX bind/server keywords from proto_uxst.c to cfgparse-unix.c
6963 - REORG: sock: start to move some generic socket code to sock.c
6964 - MINOR: sock: introduce sock_inet and sock_unix
6965 - MINOR: tcp/udp/unix: make use of proto->addrcmp() to compare addresses
6966 - MINOR: sock_inet: implement sock_inet_get_dst()
6967 - REORG: inet: replace tcp_is_foreign() with sock_inet_is_foreign()
6968 - REORG: sock_inet: move v6only_default from proto_tcp.c to sock_inet.c
6969 - REORG: sock_inet: move default_tcp_maxseg from proto_tcp.c
6970 - REORG: listener: move xfer_sock_list to sock.{c,h}.
6971 - MINOR: sock: add interface and namespace length to xfer_sock_list
6972 - MINOR: sock: implement sock_find_compatible_fd()
6973 - MINOR: sock_inet: move the IPv4/v6 transparent mode code to sock_inet
6974 - REORG: sock: move get_old_sockets() from haproxy.c
6975 - MINOR: sock: do not use LI_O_* in xfer_sock_list anymore
6976 - MINOR: sock: distinguish dgram from stream types when retrieving old sockets
6977 - BUILD: sock_unix: fix build issue with isdigit()
6978 - BUG/MEDIUM: http-ana: Don't wait to send 1xx responses received from servers
6979 - MINOR: http-htx: Add an option to eval query-string when the path is replaced
6980 - BUG/MINOR: http-rules: Replace path and query-string in "replace-path" action
6981 - MINOR: http-htx: Handle an optional reason when replacing the response status
6982 - MINOR: contrib/spoa-server: allow MAX_FRAME_SIZE override
6983 - BUG/MAJOR: contrib/spoa-server: Fix unhandled python call leading to memory leak
6984 - BUG/MINOR: contrib/spoa-server: Ensure ip address references are freed
6985 - BUG/MINOR: contrib/spoa-server: Do not free reference to NULL
6986 - BUG/MINOR: contrib/spoa-server: Updating references to free in case of failure
6987 - BUG/MEDIUM: contrib/spoa-server: Fix ipv4_address used instead of ipv6_address
6988 - CLEANUP: http: silence a cppcheck warning in get_http_auth()
6989 - REGTEST: increase some short timeouts to make tests more reliable
6990 - BUG/MINOR: threads: work around a libgcc_s issue with chrooting
6991 - BUILD: thread: limit the libgcc_s workaround to glibc only
6992 - MINOR: protocol: do not call proto->bind_all() anymore
6993 - MINOR: protocol: do not call proto->unbind_all() anymore
6994 - CLEANUP: protocol: remove all ->bind_all() and ->unbind_all() functions
6995 - MAJOR: init: start all listeners via protocols and not via proxies anymore
6996 - BUG/MINOR: startup: haproxy -s cause 100% cpu
6997 - Revert "BUG/MINOR: http-rules: Replace path and query-string in "replace-path" action"
6998 - BUG/MEDIUM: doc: Fix replace-path action description
6999 - MINOR: http-rules: Add set-pathq and replace-pathq actions
7000 - MINOR: http-fetch: Add pathq sample fetch
7001 - REGTEST: Add a test for request path manipulations, with and without the QS
7002 - MINOR: Commit .gitattributes
7003 - CLEANUP: Update .gitignore
7004 - BUG/MEDIUM: dns: Don't store additional records in a linked-list
7005 - BUG/MEDIUM: dns: Be sure to renew IP address for already known servers
7006 - MINOR: server: Improve log message sent when server address is updated
7007 - DOC: ssl-load-extra-files only applies to certificates on bind lines
7008 - BUG/MINOR: auth: report valid crypto(3) support depending on build options
7009 - BUG/MEDIUM: mux-h1: always apply the timeout on half-closed connections
7010 - BUILD: threads: better workaround for late loading of libgcc_s
7011 - BUILD: compiler: reserve the gcc version checks to the gcc compiler
7012 - BUILD: compiler: workaround a glibc madness around __attribute__()
7013 - BUILD: intops: on x86_64, the bswap instruction is called bswapq
7014 - BUILD: trace: always have an argument before variadic args in macros
7015 - BUILD: traces: don't pass an empty argument for missing ones
7016 - BUG/MINOR: haproxy: Free uri_auth->scope during deinit
7017 - CLEANUP: Free old_argv on deinit
7018 - CLEANUP: haproxy: Free post_proxy_check_list in deinit()
7019 - CLEANUP: haproxy: Free per_thread_*_list in deinit()
7020 - CLEANUP: haproxy: Free post_check_list in deinit()
7021 - BUG/MEDIUM: pattern: Renew the pattern expression revision when it is pruned
7022 - REORG: tools: move PARSE_OPT_* from tools.h to tools-t.h
7023 - MINOR: sample: Add iif(<true>,<false>) converter
7024
Willy Tarreauf104b532020-08-14 18:54:05 +020070252020/08/14 : 2.3-dev3
7026 - SCRIPTS: git-show-backports: make -m most only show the left branch
7027 - SCRIPTS: git-show-backports: emit the shell command to backport a commit
7028 - BUILD: Makefile: require SSL_LIB, SSL_INC to be explicitly set
7029 - CI: travis-ci: specify SLZ_LIB, SLZ_INC for travis builds
7030 - BUG/MEDIUM: mux-h1: Refresh H1 connection timeout after a synchronous send
7031 - CLEANUP: dns: typo in reported error message
7032 - BUG/MAJOR: dns: disabled servers through SRV records never recover
7033 - BUG/MINOR: spoa-server: fix size_t format printing
7034 - DOC: spoa-server: fix false friends `actually`
7035 - BUG/MINOR: ssl: fix memory leak at OCSP loading
7036 - BUG/MEDIUM: ssl: memory leak of ocsp data at SSL_CTX_free()
7037 - BUG/MEDIUM: map/lua: Return an error if a map is loaded during runtime
7038 - MINOR: arg: Add an argument type to keep a reference on opaque data
7039 - BUG/MINOR: converters: Store the sink in an arg pointer for debug() converter
7040 - BUG/MINOR: lua: Duplicate map name to load it when a new Map object is created
7041 - BUG/MINOR: arg: Fix leaks during arguments validation for fetches/converters
7042 - BUG/MINOR: lua: Check argument type to convert it to IPv4/IPv6 arg validation
7043 - BUG/MINOR: lua: Check argument type to convert it to IP mask in arg validation
7044 - MINOR: hlua: Don't needlessly copy lua strings in trash during args validation
7045 - BUG/MINOR: lua: Duplicate lua strings in sample fetches/converters arg array
7046 - MEDIUM: lua: Don't filter exported fetches and converters
7047 - MINOR: lua: Add support for userlist as fetches and converters arguments
7048 - MINOR: lua: Add support for regex as fetches and converters arguments
7049 - MINOR: arg: Use chunk_destroy() to release string arguments
7050 - BUG/MINOR: snapshots: leak of snapshots on deinit()
7051 - CLEANUP: ssl: ssl_sock_crt2der semicolon and spaces
7052 - MINOR: ssl: add ssl_{c,s}_chain_der fetch methods
7053 - CLEANUP: fix all duplicated semicolons
7054 - BUG/MEDIUM: ssl: fix the ssl-skip-self-issued-ca option
7055 - BUG/MINOR: ssl: ssl-skip-self-issued-ca requires >= 1.0.2
7056 - BUG/MINOR: stats: use strncmp() instead of memcmp() on health states
7057 - BUILD: makefile: don't disable -Wstringop-overflow anymore
7058 - BUG/MINOR: ssl: double free w/ smp_fetch_ssl_x_chain_der()
7059 - BUG/MEDIUM: htx: smp_prefetch_htx() must always validate the direction
7060 - BUG/MEDIUM: ssl: never generates the chain from the verify store
7061 - OPTIM: regex: PCRE2 use JIT match when JIT optimisation occured.
7062 - BUG/MEDIUM: ssl: does not look for all SNIs before chosing a certificate
7063 - CLEANUP: ssl: remove poorly readable nested ternary
7064
Willy Tarreau3f3cc8c2020-07-31 14:48:32 +020070652020/07/31 : 2.3-dev2
7066 - DOC: ssl: req_ssl_sni needs implicit TLS
7067 - BUG/MEDIUM: arg: empty args list must be dropped
7068 - BUG/MEDIUM: resolve: fix init resolving for ring and peers section.
7069 - BUG/MAJOR: tasks: don't requeue global tasks into the local queue
7070 - MINOR: tasks/debug: make the thread affinity BUG_ON check a bit stricter
7071 - MINOR: tasks/debug: add a few BUG_ON() to detect use of wrong timer queue
7072 - MINOR: tasks/debug: add a BUG_ON() check to detect requeued task on free
7073 - BUG/MAJOR: dns: Make the do-resolve action thread-safe
7074 - BUG/MEDIUM: dns: Release answer items when a DNS resolution is freed
7075 - MEDIUM: htx: Add a flag on a HTX message when no more data are expected
7076 - BUG/MEDIUM: stream-int: Don't set MSG_MORE flag if no more data are expected
7077 - BUG/MEDIUM: http-ana: Only set CF_EXPECT_MORE flag on data filtering
7078 - CLEANUP: dns: remove 45 "return" statements from dns_validate_dns_response()
7079 - BUG/MINOR: htx: add two missing HTX_FL_EOI and remove an unexpected one
7080 - BUG/MINOR: mux-fcgi: Don't url-decode the QUERY_STRING parameter anymore
7081 - BUILD: tools: fix build with static only toolchains
7082 - DOC: Use gender neutral language
7083 - BUG/MINOR: debug: Don't dump the lua stack if it is not initialized
7084 - BUG/MAJOR: dns: fix null pointer dereference in snr_update_srv_status
7085 - BUG/MAJOR: dns: don't treat Authority records as an error
7086 - CI : travis-ci : prepare for using stock OpenSSL
7087 - CI: travis-ci : switch to stock openssl when openssl-1.1.1 is used
7088 - MEDIUM: lua: Add support for the Lua 5.4
7089 - BUG/MEDIUM: dns: Don't yield in do-resolve action on a final evaluation
7090 - BUG/MINOR: lua: Abort execution of actions that yield on a final evaluation
7091 - MINOR: tcp-rules: Return an internal error if an action yields on a final eval
7092 - BUG/MINOR: tcp-rules: Preserve the right filter analyser on content eval abort
7093 - BUG/MINOR: tcp-rules: Set the inspect-delay when a tcp-response action yields
7094 - MEDIUM: tcp-rules: Use a dedicated expiration date for tcp ruleset
7095 - MEDIUM: lua: Set the analyse expiration date with smaller wake_time only
7096 - BUG/MEDIUM: connection: Be sure to always install a mux for sync connect
7097 - MINOR: connection: Preinstall the mux for non-ssl connect
7098 - MINOR: stream-int: Be sure to have a mux to do sends and receives
7099 - BUG/MINOR: lua: Fix a possible null pointer deref on lua ctx
7100 - SCRIPTS: announce-release: add the link to the wiki in the announce messages
7101 - CI: travis-ci: use better name for Coverity scan job
7102 - CI: travis-ci: use proper linking flags for SLZ build
7103 - BUG/MEDIUM: backend: always attach the transport before installing the mux
7104 - BUG/MEDIUM: tcp-checks: always attach the transport before installing the mux
7105 - MINOR: connection: avoid a useless recvfrom() on outgoing connections
7106 - MINOR: mux-h1: do not even try to receive if the connection is not fully set up
7107 - MINOR: mux-h1: do not try to receive on backend before sending a request
7108 - CLEANUP: assorted typo fixes in the code and comments
7109 - BUG/MEDIUM: ssl: check OCSP calloc in ssl_sock_load_ocsp()
7110
Willy Tarreaue732cbd2020-07-17 15:13:19 +020071112020/07/17 : 2.3-dev1
7112 - MINOR: config: make strict limits enabled by default
7113 - BUG/MINOR: acl: Fix freeing of expr->smp in prune_acl_expr
7114 - BUG/MINOR: sample: Fix freeing of conv_exprs in release_sample_expr
7115 - BUG/MINOR: haproxy: Free proxy->format_unique_id during deinit
7116 - BUG/MINOR: haproxy: Add missing free of server->(hostname|resolvers_id)
7117 - BUG/MINOR: haproxy: Free proxy->unique_id_header during deinit
7118 - BUG/MINOR: haproxy: Free srule->file during deinit
7119 - BUG/MINOR: haproxy: Free srule->expr during deinit
7120 - BUG/MINOR: sample: Free str.area in smp_check_const_bool
7121 - BUG/MINOR: sample: Free str.area in smp_check_const_meth
7122 - CLEANUP: haproxy: Free proxy_deinit_list in deinit()
7123 - CLEANUP: haproxy: Free post_deinit_list in deinit()
7124 - CLEANUP: haproxy: Free server_deinit_list in deinit()
7125 - CLEANUP: haproxy: Free post_server_check_list in deinit()
7126 - CLEANUP: Add static void vars_deinit()
7127 - CLEANUP: Add static void hlua_deinit()
7128 - CLEANUP: contrib/prometheus-exporter: typo fixes for ssl reuse metric
7129 - BUG/MEDIUM: lists: add missing store barrier on MT_LIST_BEHEAD()
7130 - BUG/MEDIUM: lists: add missing store barrier in MT_LIST_ADD/MT_LIST_ADDQ
7131 - MINOR: tcp: Support TCP keepalive parameters customization
7132 - BUILD: tcp: condition TCP keepalive settings to platforms providing them
7133 - MINOR: lists: rename some MT_LIST operations to clarify them
7134 - MINOR: buffer: use MT_LIST_ADDQ() for buffer_wait lists additions
7135 - MINOR: connection: use MT_LIST_ADDQ() to add connections to idle lists
7136 - MINOR: tasks: use MT_LIST_ADDQ() when killing tasks.
7137 - CONTRIB: da: fix memory leak in dummy function da_atlas_open()
7138 - CI: travis-ci: speed up osx build by running brew scripted, switch to latest osx image
7139 - BUG/MEDIUM: mux-h2: Don't add private connections in available connection list
7140 - BUG/MEDIUM: mux-fcgi: Don't add private connections in available connection list
7141 - MINOR: connection: Set the SNI on server connections before installing the mux
7142 - MINOR: connection: Set new connection as private on reuse never
7143 - MINOR: connection: Add a wrapper to mark a connection as private
7144 - MEDIUM: connection: Add private connections synchronously in session server list
7145 - MINOR: connection: Use a dedicated function to look for a session's connection
7146 - MINOR: connection: Set the conncetion target during its initialisation
7147 - MINOR: session: Take care to decrement idle_conns counter in session_unown_conn
7148 - MINOR: server: Factorize code to deal with reuse of server idle connections
7149 - MINOR: server: Factorize code to deal with connections removed from an idle list
7150 - CLEANUP: connection: remove unused field idle_time from the connection struct
7151 - BUG/MEDIUM: mux-h1: Continue to process request when switching in tunnel mode
7152 - MINOR: raw_sock: Report the number of bytes emitted using the splicing
7153 - MINOR: contrib/prometheus-exporter: Add missing global and per-server metrics
7154 - MINOR: backend: Add sample fetches to get the server's weight
7155 - BUG/MINOR: mux-fcgi: Handle empty STDERR record
7156 - BUG/MINOR: mux-fcgi: Set conn state to RECORD_P when skipping the record padding
7157 - BUG/MINOR: mux-fcgi: Set flags on the right stream field for empty FCGI_STDOUT
7158 - BUG/MINOR: backend: fix potential null deref on srv_conn
7159 - BUG/MEDIUM: log: issue mixing sampled to not sampled log servers.
7160 - MEDIUM: udp: adds minimal proto udp support for message listeners.
7161 - MEDIUM: log/sink: re-work and merge of build message API.
7162 - MINOR: log: adds syslog udp message handler and parsing.
7163 - MEDIUM: log: adds log forwarding section.
7164 - MINOR: log: adds counters on received syslog messages.
7165 - BUG/MEDIUM: fcgi-app: fix memory leak in fcgi_flt_http_headers
7166 - BUG/MEDIUM: server: resolve state file handle leak on reload
7167 - BUG/MEDIUM: server: fix possibly uninitialized state file on close
7168 - BUG/MEDIUM: channel: Be aware of SHUTW_NOW flag when output data are peeked
7169 - BUILD: config: address build warning on raspbian+rpi4
7170 - BUG/MAJOR: tasks: make sure to always lock the shared wait queue if needed
7171 - BUILD: config: fix again bugs gcc warnings on calloc
7172
Willy Tarreau33205c22020-07-07 16:35:28 +020071732020/07/07 : 2.3-dev0
Willy Tarreau848dbdf2020-07-07 16:39:18 +02007174 - [RELEASE] Released version 2.3-dev0
7175 - MINOR: version: back to development, update status message
7176
71772020/07/07 : 2.3-dev0
Willy Tarreau33205c22020-07-07 16:35:28 +02007178 - exact copy of 2.2.0
7179
Willy Tarreau3a00c912020-07-07 16:33:14 +020071802020/07/07 : 2.2.0
7181 - BUILD: mux-h2: fix typo breaking build when using DEBUG_LOCK
7182 - CLEANUP: makefile: update the outdated list of DEBUG_xxx options
7183 - BUILD: tools: make resolve_sym_name() return a const
7184 - CLEANUP: auth: fix useless self-include of auth-t.h
7185 - BUILD: tree-wide: cast arguments to tolower/toupper to unsigned char
7186 - CLEANUP: assorted typo fixes in the code and comments
7187 - WIP/MINOR: ssl: add sample fetches for keylog in frontend
7188 - DOC: fix tune.ssl.keylog sample fetches array
7189 - BUG/MINOR: ssl: check conn in keylog sample fetch
7190 - DOC: configuration: various typo fixes
7191 - MINOR: log: Remove unused case statement during the log-format string parsing
7192 - BUG/MINOR: mux-h1: Fix the splicing in TUNNEL mode
7193 - BUG/MINOR: mux-h1: Don't read data from a pipe if the mux is unable to receive
7194 - BUG/MINOR: mux-h1: Disable splicing only if input data was processed
7195 - BUG/MEDIUM: mux-h1: Disable splicing for the conn-stream if read0 is received
7196 - MINOR: mux-h1: Improve traces about the splicing
7197 - BUG/MINOR: backend: Remove CO_FL_SESS_IDLE if a client remains on the last server
7198 - BUG/MEDIUM: connection: Don't consider new private connections as available
7199 - BUG/MINOR: connection: See new connection as available only on reuse always
7200 - DOC: configuration: remove obsolete mentions of H2 being converted to HTTP/1.x
7201 - CLEANUP: ssl: remove unrelevant comment in smp_fetch_ssl_x_keylog()
7202 - DOC: update INSTALL with new compiler versions
7203 - DOC: minor update to coding style file
7204 - MINOR: version: mention that it's an LTS release now
7205
Willy Tarreau62f11a52020-07-04 07:10:24 +020072062020/07/04 : 2.2-dev12
7207 - BUG/MINOR: mux_h2: don't lose the leaving trace in h2_io_cb()
7208 - MINOR: cli: make "show sess" stop at the last known session
7209 - CLEANUP: buffers: remove unused buffer_wq_lock lock
7210 - BUG/MEDIUM: buffers: always allocate from the local cache first
7211 - MINOR: connection: align toremove_{lock,connections} and cleanup into idle_conns
7212 - CONTRIB: debug: add missing flags SI_FL_L7_RETRY & SI_FL_D_L7_RETRY
7213 - BUG/MEDIUM: connections: Don't increase curr_used_conns for shared connections.
7214 - BUG/MEDIUM: checks: Increment the server's curr_used_conns
7215 - REORG: buffer: rename buffer.c to dynbuf.c
7216 - REORG: includes: create tinfo.h for the thread_info struct
7217 - CLEANUP: pool: only include the type files from types
7218 - MINOR: pools: move the LRU cache heads to thread_info
7219 - BUG/MINOR: debug: fix "show fd" null-deref when built with DEBUG_FD
7220 - MINOR: stats: add 3 new output values for the per-server idle conn state
7221 - MINOR: activity: add per-thread statistics on FD takeover
7222 - BUG/MINOR: server: start cleaning idle connections from various points
7223 - MEDIUM: server: improve estimate of the need for idle connections
7224 - MINOR: stats: add the estimated need of concurrent connections per server
7225 - BUG/MINOR: threads: Don't forget to init each thread toremove_lock.
7226 - BUG/MEDIUM: lists: Lock the element while we check if it is in a list.
7227 - Revert "BUG/MEDIUM: lists: Lock the element while we check if it is in a list."
7228 - BUG/MINOR: haproxy: don't wake already stopping threads on exit
7229 - BUG/MINOR: server: always count one idle slot for current thread
7230 - MEDIUM: server: use the two thresholds for the connection release algorithm
7231 - BUG/MINOR: http-rules: Fix ACLs parsing for http deny rules
7232 - BUG/MINOR: sched: properly cover for a rare MT_LIST_ADDQ() race
7233 - MINOR: mux-h1: avoid taking the toremove_lock in on dying tasks
7234 - MINOR: mux-h2: avoid taking the toremove_lock in on dying tasks
7235 - MINOR: mux-fcgi: avoid taking the toremove_lock in on dying tasks
7236 - MINOR: pools: increase MAX_BASE_POOLS to 64
7237 - DOC: ssl: add "allow-0rtt" and "ciphersuites" in crt-list
7238 - BUG/MEDIUM: pattern: Add a trailing \0 to match strings only if possible
7239 - BUG/MEDIUM: log-format: fix possible endless loop in parse_logformat_string()
7240 - BUG/MINOR: proxy: fix dump_server_state()'s misuse of the trash
7241 - BUG/MINOR: proxy: always initialize the trash in show servers state
7242 - MINOR: cli/proxy: add a new "show servers conn" command
7243 - MINOR: server: skip servers with no idle conns earlier
7244 - BUG/MINOR: server: fix the connection release logic regarding nearly full conditions
7245 - MEDIUM: server: add a new pool-low-conn server setting
7246 - BUG/MEDIUM: backend: always search in the safe list after failing on the idle one
7247 - MINOR: backend: don't always takeover from the same threads
7248 - MINOR: sched: make sched->task_list_size atomic
7249 - MEDIUM: sched: create a new TASK_KILLED task flag
7250 - MEDIUM: sched: implement task_kill() to kill a task
7251 - MEDIUM: mux-h1: use task_kill() during h1_takeover() instead of task_wakeup()
7252 - MEDIUM: mux-h2: use task_kill() during h2_takeover() instead of task_wakeup()
7253 - MEDIUM: mux-fcgi: use task_kill() during fcgi_takeover() instead of task_wakeup()
7254 - MINOR: list: Add MT_LIST_DEL_SAFE_NOINIT() and MT_LIST_ADDQ_NOCHECK()
7255 - CLEANUP: connections: rename the toremove_lock to takeover_lock
7256 - MEDIUM: connections: Don't use a lock when moving connections to remove.
7257 - DOC: configuration: add missing index entries for tune.pool-{low,high}-fd-ratio
7258 - DOC: configuration: fix alphabetical ordering for tune.pool-{high,low}-fd-ratio
7259 - MINOR: config: add a new tune.idle-pool.shared global setting.
7260 - MINOR: 51d: silence a warning about null pointer dereference
7261 - MINOR: debug: add a new "debug dev memstats" command
7262 - MINOR: log-format: allow to preserve spacing in log format strings
7263 - BUILD: debug: avoid build warnings with DEBUG_MEM_STATS
7264 - BUG/MAJOR: sched: make sure task_kill() always queues the task
7265 - BUG/MEDIUM: muxes: Make sure nobody stole the connection before using it.
7266 - BUG/MEDIUM: cli/proxy: don't try to dump idle connection state if there's none
7267 - BUILD: haproxy: fix build error when RLIMIT_AS is not set
7268 - BUG/MAJOR: sched: make it work also when not building with DEBUG_STRICT
7269 - MINOR: log: add time second fraction field to rfc5424 log timestamp.
7270 - BUG/MINOR: log: missing timezone on iso dates.
7271 - BUG/MEDIUM: server: don't kill all idle conns when there are not enough
7272 - MINOR: sched: split tasklet_wakeup() into tasklet_wakeup_on()
7273 - BUG/MEDIUM: connections: Set the tid for the old tasklet on takeover.
7274 - BUG/MEDIUM: connections: Let the xprt layer know a takeover happened.
7275 - BUG/MINOR: http_act: don't check capture id in backend (2)
7276 - BUILD: makefile: disable threads by default on OpenBSD
7277 - BUILD: peers: fix build warning with gcc 4.2.1
7278 - CI: cirrus-ci: exclude slow reg-tests
7279
Willy Tarreau4462af82020-06-26 22:01:04 +020072802020/06/26 : 2.2-dev11
7281 - REGTEST: Add a simple script to tests errorfile directives in proxy sections
7282 - BUG/MEDIUM: fcgi-app: Resolve the sink if a fcgi-app logs in a ring buffer
7283 - BUG/MINOR: spoe: correction of setting bits for analyzer
7284 - BUG/MINOR: cfgparse: Support configurations without newline at EOF
7285 - MINOR: cfgparse: Warn on truncated lines / files
7286 - BUG/MINOR: http_ana: clarify connection pointer check on L7 retry
7287 - MINOR: debug: add a new DEBUG_FD build option
7288 - BUG/MINOR: tasks: make sure never to exceed max_processed
7289 - MINOR: task: add a new pointer to current tasklet queue
7290 - BUG/MEDIUM: task: be careful not to run too many tasks at TL_URGENT
7291 - BUG/MINOR: cfgparse: Fix argument reference in PARSE_ERR_TOOMANY message
7292 - BUG/MINOR: cfgparse: Fix calculation of position for PARSE_ERR_TOOMANY message
7293 - BUG/MEDIUM: ssl: fix ssl_bind_conf double free
7294 - MINOR: ssl: free bind_conf_node in crtlist_free()
7295 - MINOR: ssl: free the crtlist and the ckch during the deinit()
7296 - BUG/MINOR: ssl: fix build with ckch_deinit() and crtlist_deinit()
7297 - BUG/MINOR: ssl/cli: certs added from the CLI can't be deleted
7298 - MINOR: ssl: move the ckch/crtlist deinit to ssl_sock.c
7299 - MEDIUM: tasks: apply a fair CPU distribution between tasklet classes
7300 - MINOR: tasks: make current_queue an index instead of a pointer
7301 - MINOR: tasks: add a mask of the queues with active tasklets
7302 - MINOR: tasks: pass the queue index to run_task_from_list()
7303 - MINOR: tasks: make run_tasks_from_lists() scan the queues itself
7304 - MEDIUM: tasks: add a tune.sched.low-latency option
7305 - BUG/MEDIUM: ssl/cli: 'commit ssl cert' crashes when no private key
7306 - BUG/MINOR: cfgparse: don't increment linenum on incomplete lines
7307 - MINOR: tools: make parse_line() always terminate the args list
7308 - BUG/MINOR: cfgparse: report extraneous args *after* the string is allocated
7309 - MINOR: cfgparse: sanitize the output a little bit
7310 - MINOR: cli/ssl: handle trailing slashes in crt-list commands
7311 - MINOR: ssl: add the ssl_s_* sample fetches for server side certificate
7312 - BUG/MEDIUM: http-ana: Don't loop trying to generate a malformed 500 response
7313 - BUG/MINOR: stream-int: Don't wait to send truncated HTTP messages
7314 - BUG/MINOR: http-ana: Set CF_EOI on response channel for generated responses
7315 - BUG/MINOR: http-ana: Don't wait to send 1xx responses generated by HAProxy
7316 - MINOR: spoe: Don't systematically create new applets if processing rate is low
7317 - DOC: fix some typos in the ssl_s_{s|i}_dn documentation
7318 - BUILD: fix ssl_sample.c when building against BoringSSL
7319 - CI: travis-ci: switch BoringSSL builds to ninja
7320 - CI: extend spellchecker whitelist
7321 - DOC: assorted typo fixes in the documentation
7322 - CLEANUP: assorted typo fixes in the code and comments
7323 - MINOR: http: Add support for http 413 status
7324 - REGTEST: ssl: tests the ssl_f_* sample fetches
7325 - REGTEST: ssl: add some ssl_c_* sample fetches test
7326 - DOC: ssl: update the documentation of "commit ssl cert"
7327 - BUG/MINOR: cfgparse: correctly deal with empty lines
7328 - BUG/MEDIUM: fetch: Fix hdr_ip misparsing IPv4 addresses due to missing NUL
7329
Willy Tarreaudc0936c2020-06-19 21:43:26 +020073302020/06/19 : 2.2-dev10
7331 - BUILD: include: add sys/types before netinet/tcp.h
7332 - BUG/MEDIUM: log: don't hold the log lock during writev() on a file descriptor
7333 - BUILD: Remove nowarn for warnings that do not trigger
7334 - BUG/MEDIUM: pattern: fix thread safety of pattern matching
7335 - BUILD: Re-enable -Wimplicit-fallthrough
7336 - BUG/MINOR: ssl: fix ssl-{min,max}-ver with openssl < 1.1.0
7337 - BUILD: thread: add parenthesis around values of locking macros
7338 - BUILD: proto_uxst: shut up yet another gcc's absurd warning
7339 - BUG/MEDIUM: checks: Fix off-by-one in allocation of SMTP greeting cmd
7340 - CI: travis-ci: use "-O1" for clang builds
7341 - MINOR: haproxy: Add void deinit_and_exit(int)
7342 - MINOR: haproxy: Make use of deinit_and_exit() for clean exits
7343 - BUG/MINOR: haproxy: Free rule->arg.vars.expr during deinit_act_rules
7344 - BUILD: compression: make gcc 10 happy with free_zlib()
7345 - BUILD: atomic: add string.h for memcpy() on ARM64
7346 - BUG/MINOR: http: make smp_fetch_body() report that the contents may change
7347 - BUG/MINOR: tcp-rules: tcp-response must check the buffer's fullness
7348 - BUILD: haproxy: mark deinit_and_exit() as noreturn
7349 - BUG/MAJOR: vars: Fix bogus free() during deinit() for http-request rules
7350 - BUG/MEDIUM: ebtree: use a byte-per-byte memcmp() to compare memory blocks
7351 - MINOR: tools: add a new configurable line parse, parse_line()
7352 - BUG/MEDIUM: cfgparse: use parse_line() to expand/unquote/unescape config lines
7353 - BUG/MEDIUM: cfgparse: stop after a reasonable amount of fatal error
7354 - MINOR: http: do not close connections anymore after internal responses
7355 - BUG/MINOR: cfgparse: Add missing fatal++ in PARSE_ERR_HEX case
7356 - BUG/MINOR: spoe: add missing key length check before checking key names
7357 - MINOR: version: put the compiler version output into version.c not haproxy.c
7358 - MINOR: compiler: always define __has_feature()
7359 - MINOR: version: report the presence of the compiler's address sanitizer
7360 - BUILD: Fix build by including haproxy/global.h
7361 - BUG/MAJOR: connection: always disable ready events once reported
7362 - CLEANUP: activity: remove unused counter fd_lock
7363 - DOC: fd: make it clear that some fields ordering must absolutely be respected
7364 - MINOR: activity: report the number of times poll() reports I/O
7365 - MINOR: activity: rename confusing poll_* fields in the output
7366 - MINOR: fd: Fix a typo in a coment.
7367 - BUG/MEDIUM: fd: Don't fd_stop_recv() a fd we don't own.
7368 - BUG/MEDIUM: fd: Call fd_stop_recv() when we just got a fd.
7369 - MINOR: activity: group the per-loop counters at the top
7370 - MINOR: activity: rename the "stream" field to "stream_calls"
7371 - MEDIUM: fd: refine the fd_takeover() migration lock
7372 - MINOR: fd: slightly optimize the fd_takeover double-CAS loop
7373 - MINOR: fd: factorize the fd_takeover() exit path to make it safer
7374 - MINOR: peers: do not use localpeer as an array anymore
7375 - MEDIUM: peers: add the "localpeer" global option
7376 - MEDIUM: fd: add experimental support for edge-triggered polling
7377 - CONTRIB: debug: add the missing flags CO_FL_SAFE_LIST and CO_FL_IDLE_LIST
7378 - MINOR: haproxy: process signals before runnable tasks
7379 - MEDIUM: tasks: clean up the front side of the wait queue in wake_expired_tasks()
7380 - MEDIUM: tasks: also process late wakeups in process_runnable_tasks()
7381 - BUG/MINOR: cli: allow space escaping on the CLI
7382 - BUG/MINOR: mworker/cli: fix the escaping in the master CLI
7383 - BUG/MINOR: mworker/cli: fix semicolon escaping in master CLI
7384 - REGTEST: http-rules: test spaces in ACLs
7385 - REGTEST: http-rules: test spaces in ACLs with master CLI
7386 - BUG/MAJOR: init: properly compute the default global.maxpipes value
7387 - MEDIUM: map: make the "clear map" operation yield
7388 - BUG/MEDIUM: stream-int: fix loss of CO_SFL_MSG_MORE flag in forwarding
7389 - MINOR: mux_h1: Set H1_F_CO_MSG_MORE if we know we have more to send.
7390 - BUG/MINOR: systemd: Wait for network to be online
7391 - DOC: configuration: Unindent non-code sentences in the protobuf example
7392 - DOC: configuration: http-check send was missing from matrix
7393
Willy Tarreau1385c882020-06-11 10:22:10 +020073942020/06/11 : 2.2-dev9
7395 - BUG/MINOR: http-htx: Don't forget to release the http reply in release function
7396 - BUG/MINOR: http-htx: Fix a leak on error path during http reply parsing
7397 - MINOR: checks: Remove dead code from process_chk_conn()
7398 - REGTESTS: checks: Fix tls_health_checks when IPv6 addresses are used
7399 - REGTESTS: Add missing OPENSSL to REQUIRE_OPTIONS for lua/txn_get_priv
7400 - MINOR: lua: Use vars_unset_by_name_ifexist()
7401 - CLEANUP: vars: Remove void vars_unset_by_name(const char*, size_t, struct sample*)
7402 - MINOR: vars: Make vars_(un|)set_by_name(_ifexist|) return a success value
7403 - MINOR: lua: Make `set_var()` and `unset_var()` return success
7404 - MEDIUM: lua: Add `ifexist` parameter to `set_var`
7405 - MEDIUM: ring: new section ring to declare custom ring buffers.
7406 - REGTESTS: Add missing OPENSSL to REQUIRE_OPTIONS for compression/lua_validation
7407 - REGTESTS: Require the version 2.2 to execute lua/set_var
7408 - BUG/MEDIUM: checks: Refresh the conn-stream and the connection after a connect
7409 - MINOR: checks: Remove useless tests on the connection and conn-stream
7410 - BUG/MEDIUM: contrib/spoa: do not register python3.8 if --embed fail
7411 - BUG/MEDIUM: connection: Ignore PP2 unique ID for stream-less connections
7412 - BUG/MINOR: connection: Always get the stream when available to send PP2 line
7413 - BUG/MEDIUM: backend: set the connection owner to the session when using alpn.
7414 - MINOR: pools: compute an estimate of each pool's average needed objects
7415 - MEDIUM: pools: directly free objects when pools are too much crowded
7416 - REGTEST: Add connection/proxy_protocol_send_unique_id_alpn
7417 - MINOR: http-ana: Make the function http_reply_to_htx() public
7418 - MINOR: http-ana: Use proxy's error replies to emit 401/407 responses
7419 - MINOR: http-rules: Use an action function to eval http-request auth rules
7420 - CLEANUP: http: Remove unused HTTP message templates
7421 - BUG/MEDIUM: checks: Don't blindly subscribe for receive if waiting for connect
7422 - MINOR: checks: I/O callback function only rely on the data layer wake callback
7423 - BUG/MINOR: lua: Add missing string length for lua sticktable lookup
7424 - BUG/MEDIUM: logs: fix trailing zeros on log message.
7425 - CI: cirrus-ci: skip reg-tests/connection/proxy_protocol_send_unique_id_alpn.vtc on CentOS 6
7426 - BUG/MINOR: nameservers: fix error handling in parsing of resolv.conf
7427 - BUG/MEDIUM: checks: Don't add a tcpcheck ruleset twice in the shared tree
7428 - MEDIUM: ssl: use TLSv1.2 as the minimum default on bind lines
7429 - CLEANUP: pools: use the regular lock for the flush operation on lockless pools
7430 - SCRIPTS: publish-release: pass -n to gzip to remove timestamp
7431 - MINOR: ring: re-work ring attach generic API.
7432 - BUG/MINOR: error on unknown statement in ring section.
7433 - MEDIUM: ring: add server statement to forward messages from a ring
7434 - MEDIUM: ring: add new srv statement to support octet counting forward
7435 - MINOR: ssl: set ssl-min-ver in ambiguous configurations
7436 - CLEANUP: ssl: remove comment from dump_crtlist_sslconf()
7437 - BUILD: sink: address build warning on 32-bit architectures
7438 - BUG/MINOR: peers: fix internal/network key type mapping.
7439 - CLEANUP: regex: remove outdated support for regex actions
7440 - Revert "MINOR: ssl: rework add cert chain to CTX to be libssl independent"
7441 - MINOR: mux-h1/proxy: Add a proxy option to disable clear h2 upgrade
7442 - BUG/MEDIUM: lua: Reset analyse expiration timeout before executing a lua action
7443 - DOC: add a line about comments in crt-list
7444 - BUG/MEDIUM: hlua: Lock pattern references to perform set/add/del operations
7445 - BUG/MINOR: checks: Fix test on http-check rulesets during config validity check
7446 - BUG/MEDIUM: contrib/prometheus-exporter: Properly set flags to dump metrics
7447 - BUG/MEDIUM: mworker: fix the copy of options in copy_argv()
7448 - BUG/MINOR: init: -x can have a parameter starting with a dash
7449 - BUG/MINOR: init: -S can have a parameter starting with a dash
7450 - BUG/MEDIUM: mworker: fix the reload with an -- option
7451 - BUG/MINOR: ssl: fix a trash buffer leak in some error cases
7452 - BUG/MINOR: mworker: fix a memleak when execvp() failed
7453 - MINOR: sample: Add secure_memcmp converter
7454 - REORG: ebtree: move the C files from ebtree/ to src/
7455 - REORG: ebtree: move the include files from ebtree to include/import/
7456 - REORG: ebtree: clean up remains of the ebtree/ directory
7457 - REORG: include: create new file haproxy/api-t.h
7458 - REORG: include: create new file haproxy/api.h
7459 - REORG: include: update all files to use haproxy/api.h or api-t.h if needed
7460 - CLEANUP: include: remove common/config.h
7461 - CLEANUP: include: remove unused template.h
7462 - REORG: include: move MIN/MAX from tools.h to compat.h
7463 - REORG: include: move SWAP/MID_RANGE/MAX_RANGE from tools.h to standard.h
7464 - CLEANUP: include: remove unused common/tools.h
7465 - REORG: include: move the base files from common/ to haproxy/
7466 - REORG: include: move version.h to haproxy/
7467 - REORG: include: move base64.h, errors.h and hash.h from common to to haproxy/
7468 - REORG: include: move openssl-compat.h from common/ to haproxy/
7469 - REORG: include: move ist.h from common/ to import/
7470 - REORG: include: move the BUG_ON() code to haproxy/bug.h
7471 - REORG: include: move debug.h from common/ to haproxy/
7472 - CLEANUP: debug: drop unused function p_malloc()
7473 - REORG: include: split buf.h into haproxy/buf-t.h and haproxy/buf.h
7474 - REORG: include: move istbuf.h to haproxy/
7475 - REORG: include: split mini-clist into haproxy/list and list-t.h
7476 - REORG: threads: extract atomic ops from hathreads.h
7477 - CLEANUP: threads: remove a few needless includes of hathreads.h
7478 - REORG: include: split hathreads into haproxy/thread.h and haproxy/thread-t.h
7479 - CLEANUP: thread: rename __decl_hathreads() to __decl_thread()
7480 - REORG: include: move time.h from common/ to haproxy/
7481 - REORG: include: move integer manipulation functions from standard.h to intops.h
7482 - CLEANUP: include: remove excessive includes of common/standard.h
7483 - REORG: include: move freq_ctr to haproxy/
7484 - CLEANUP: pool: include freq_ctr.h and remove locally duplicated functions
7485 - REORG: memory: move the pool type definitions to haproxy/pool-t.h
7486 - REORG: memory: move the OS-level allocator to haproxy/pool-os.h
7487 - MINOR: memory: don't let __pool_get_first() pick from the cache
7488 - MEDIUM: memory: don't let pool_put_to_cache() free the objects itself
7489 - MINOR: memory: move pool-specific path of the locked pool_free() to __pool_free()
7490 - MEDIUM: memory: make local pools independent on lockless pools
7491 - REORG: include: move common/memory.h to haproxy/pool.h
7492 - REORG: include: move common/chunk.h to haproxy/chunk.h
7493 - REORG: include: move activity to haproxy/
7494 - REORG: include: move common/buffer.h to haproxy/dynbuf{,-t}.h
7495 - REORG: include: move common/net_helper.h to haproxy/net_helper.h
7496 - REORG: include: move common/namespace.h to haproxy/namespace{,-t}.h
7497 - REORG: include: split common/regex.h into haproxy/regex{,-t}.h
7498 - REORG: include: split common/xref.h into haproxy/xref{,-t}.h
7499 - REORG: include: move common/ticks.h to haproxy/ticks.h
7500 - REORG: include: split common/http.h into haproxy/http{,-t}.h
7501 - REORG: include: split common/http-hdr.h into haproxy/http-hdr{,-t}.h
7502 - REORG: include: move common/h1.h to haproxy/h1.h
7503 - REORG: include: split common/htx.h into haproxy/htx{,-t}.h
7504 - REORG: include: move hpack*.h to haproxy/ and split hpack-tbl
7505 - REORG: include: move common/h2.h to haproxy/h2.h
7506 - REORG: include: move common/fcgi.h to haproxy/
7507 - REORG: include: move protocol.h to haproxy/protocol{,-t}.h
7508 - REORG: tools: split common/standard.h into haproxy/tools{,-t}.h
7509 - REORG: include: move dict.h to hparoxy/dict{,-t}.h
7510 - REORG: include: move shctx to haproxy/shctx{,-t}.h
7511 - REORG: include: move port_range.h to haproxy/port_range{,-t}.h
7512 - REORG: include: move fd.h to haproxy/fd{,-t}.h
7513 - REORG: include: move ring to haproxy/ring{,-t}.h
7514 - REORG: include: move sink.h to haproxy/sink{,-t}.h
7515 - REORG: include: move pipe.h to haproxy/pipe{,-t}.h
7516 - CLEANUP: include: remove empty raw_sock.h
7517 - REORG: include: move proto_udp.h to haproxy/proto_udp{,-t}.h
7518 - REORG: include: move proto/proto_sockpair.h to haproxy/proto_sockpair.h
7519 - REORG: include: move compression.h to haproxy/compression{,-t}.h
7520 - REORG: include: move h1_htx.h to haproxy/h1_htx.h
7521 - REORG: include: move http_htx.h to haproxy/http_htx{,-t}.h
7522 - REORG: include: move hlua.h to haproxy/hlua{,-t}.h
7523 - REORG: include: move hlua_fcn.h to haproxy/hlua_fcn.h
7524 - REORG: include: move action.h to haproxy/action{,-t}.h
7525 - REORG: include: move arg.h to haproxy/arg{,-t}.h
7526 - REORG: include: move auth.h to haproxy/auth{,-t}.h
7527 - REORG: include: move dns.h to haproxy/dns{,-t}.h
7528 - REORG: include: move flt_http_comp.h to haproxy/
7529 - REORG: include: move counters.h to haproxy/counters-t.h
7530 - REORG: include: split mailers.h into haproxy/mailers{,-t}.h
7531 - REORG: include: move capture.h to haproxy/capture{,-t}.h
7532 - REORG: include: move frontend.h to haproxy/frontend.h
7533 - REORG: include: move obj_type.h to haproxy/obj_type{,-t}.h
7534 - REORG: include: move http_rules.h to haproxy/http_rules.h
7535 - CLEANUP: include: remove unused mux_pt.h
7536 - REORG: include: move mworker.h to haproxy/mworker{,-t}.h
7537 - REORG: include: move ssl_utils.h to haproxy/ssl_utils.h
7538 - REORG: include: move ssl_ckch.h to haproxy/ssl_ckch{,-t}.h
7539 - REORG: move ssl_crtlist.h to haproxy/ssl_crtlist{,-t}.h
7540 - REORG: include: move lb_chash.h to haproxy/lb_chash{,-t}.h
7541 - REORG: include: move lb_fas.h to haproxy/lb_fas{,-t}.h
7542 - REORG: include: move lb_fwlc.h to haproxy/lb_fwlc{,-t}.h
7543 - REORG: include: move lb_fwrr.h to haproxy/lb_fwrr{,-t}.h
7544 - REORG: include: move listener.h to haproxy/listener{,-t}.h
7545 - REORG: include: move pattern.h to haproxy/pattern{,-t}.h
7546 - REORG: include: move map to haproxy/map{,-t}.h
7547 - REORG: include: move payload.h to haproxy/payload.h
7548 - REORG: include: move sample.h to haproxy/sample{,-t}.h
7549 - REORG: include: move protocol_buffers.h to haproxy/protobuf{,-t}.h
7550 - REORG: include: move vars.h to haproxy/vars{,-t}.h
7551 - REORG: include: split global.h into haproxy/global{,-t}.h
7552 - REORG: include: move task.h to haproxy/task{,-t}.h
7553 - REORG: include: move proto_tcp.h to haproxy/proto_tcp.h
7554 - REORG: include: move signal.h to haproxy/signal{,-t}.h
7555 - REORG: include: move tcp_rules.h to haproxy/tcp_rules.h
7556 - REORG: include: move connection.h to haproxy/connection{,-t}.h
7557 - REORG: include: move checks.h to haproxy/check{,-t}.h
7558 - REORG: include: move http_fetch.h to haproxy/http_fetch.h
7559 - REORG: include: move peers.h to haproxy/peers{,-t}.h
7560 - REORG: include: move stick_table.h to haproxy/stick_table{,-t}.h
7561 - REORG: include: move session.h to haproxy/session{,-t}.h
7562 - REORG: include: move trace.h to haproxy/trace{,-t}.h
7563 - REORG: include: move acl.h to haproxy/acl.h{,-t}.h
7564 - REORG: include: split common/uri_auth.h into haproxy/uri_auth{,-t}.h
7565 - REORG: move applet.h to haproxy/applet{,-t}.h
7566 - REORG: include: move stats.h to haproxy/stats{,-t}.h
7567 - REORG: include: move cli.h to haproxy/cli{,-t}.h
7568 - REORG: include: move lb_map.h to haproxy/lb_map{,-t}.h
7569 - REORG: include: move ssl_sock.h to haproxy/ssl_sock{,-t}.h
7570 - REORG: include: move stream_interface.h to haproxy/stream_interface{,-t}.h
7571 - REORG: include: move channel.h to haproxy/channel{,-t}.h
7572 - REORG: include: move http_ana.h to haproxy/http_ana{,-t}.h
7573 - REORG: include: move filters.h to haproxy/filters{,-t}.h
7574 - REORG: include: move fcgi-app.h to haproxy/fcgi-app{,-t}.h
7575 - REORG: include: move log.h to haproxy/log{,-t}.h
7576 - REORG: include: move proxy.h to haproxy/proxy{,-t}.h
7577 - REORG: include: move spoe.h to haproxy/spoe{,-t}.h
7578 - REORG: include: move backend.h to haproxy/backend{,-t}.h
7579 - REORG: include: move queue.h to haproxy/queue{,-t}.h
7580 - REORG: include: move server.h to haproxy/server{,-t}.h
7581 - REORG: include: move stream.h to haproxy/stream{,-t}.h
7582 - REORG: include: move cfgparse.h to haproxy/cfgparse.h
7583 - CLEANUP: hpack: export debug functions and move inlines to .h
7584 - REORG: check: move the e-mail alerting code to mailers.c
7585 - REORG: check: move tcpchecks away from check.c
7586 - REORG: check: move email_alert* from proxy-t.h to mailers-t.h
7587 - REORG: check: extract the external checks from check.{c,h}
7588 - CLEANUP: include: don't include stddef.h directly
7589 - CLEANUP: include: don't include proxy-t.h in global-t.h
7590 - CLEANUP: include: move sample_data out of sample-t.h
7591 - REORG: include: move the error reporting functions to from log.h to errors.h
7592 - BUILD: reorder objects in the Makefile for faster builds
7593 - CLEANUP: compiler: add a THREAD_ALIGNED macro and use it where appropriate
7594 - CLEANUP: include: make atomic.h part of the base API
7595 - REORG: include: move MAX_THREADS to defaults.h
7596 - REORG: include: move THREAD_LOCAL and __decl_thread() to compiler.h
7597 - CLEANUP: include: tree-wide alphabetical sort of include files
7598 - REORG: include: make list-t.h part of the base API
7599 - REORG: dgram: rename proto_udp to dgram
7600
Willy Tarreau73b943b2020-05-22 16:19:04 +020076012020/05/22 : 2.2-dev8
7602 - MINOR: checks: Improve report of unexpected errors for expect rules
7603 - MEDIUM: checks: Add matching on log-format string for expect rules
7604 - DOC: Fix req.body and co documentation to be accurate
7605 - MEDIUM: checks: Remove dedicated sample fetches and use response ones instead
7606 - CLEANUP: checks: sort and rename tcpcheck_expect_type types
7607 - MINOR: checks: Use dedicated actions to send log-format strings in send rules
7608 - MINOR: checks: Simplify matching on HTTP headers in HTTP expect rules
7609 - MINOR: checks/sample: Remove unnecessary tests on the sample session
7610 - REGTEST: checks: Adapt SSL error message reported when connection is rejected
7611 - MINOR: mworker: replace ha_alert by ha_warning when exiting successfuly
7612 - MINOR: checks: Support log-format string to set the URI for HTTP send rules
7613 - MINOR: checks: Support log-format string to set the body for HTTP send rules
7614 - DOC: Be more explicit about configurable check ok/error/timeout status
7615 - MINOR: checks: Make matching on HTTP headers for expect rules less obscure
7616 - BUG/MEDIUM: lua: Fix dumping of stick table entries for STD_T_DICT
7617 - BUG/MINOR: config: Make use_backend and use-server post-parsing less obscur
7618 - REGTESTS: make the http-check-send test require version 2.2
7619 - BUG/MINOR: http-ana: fix NTLM response parsing again
7620 - BUG/MEDIUM: http_ana: make the detection of NTLM variants safer
7621 - BUG/MINOR: cfgparse: Abort parsing the current line if an invalid \x sequence is encountered
7622 - MINOR: cfgparse: Improve error message for invalid \x sequences
7623 - CI: travis-ci: enable arm64 builds again
7624 - MEDIUM: ssl: increase default-dh-param to 2048
7625 - CI: travis-ci: skip pcre2 on arm64 build
7626 - CI: travis-ci: extend the build time for SSL to 60 minutes
7627 - CLEANUP: config: drop unused setting CONFIG_HAP_MEM_OPTIM
7628 - CLEANUP: config: drop unused setting CONFIG_HAP_INLINE_FD_SET
7629 - CLENAUP: config: move CONFIG_HAP_LOCKLESS_POOLS out of config.h
7630 - CLEANUP: remove THREAD_LOCAL from config.h
7631 - CI: travis-ci: upgrade LibreSSL versions
7632 - DOC: assorted typo fixes in the documentation
7633 - CI: extend spellchecker whitelist
7634 - CLEANUP: assorted typo fixes in the code and comments
7635 - MAJOR: contrib: porting spoa_server to support python3
7636 - BUG/MEDIUM: checks: Subscribe to I/O events on an unfinished connect
7637 - BUG/MINOR: checks: Don't subscribe to I/O events if it is already done
7638 - BUG/MINOR: checks: Rely on next I/O oriented rule when waiting for a connection
7639 - MINOR: checks: Don't try to send outgoing data if waiting to be able to send
7640 - MINOR: sample: Move aes_gcm_dec implementation into sample.c
7641 - MINOR: sample: Add digest and hmac converters
7642 - BUG/MEDIUM: checks: Subscribe to I/O events only if a mux was installed
7643 - BUG/MINOR: sample/ssl: Fix digest converter for openssl < 1.1.0
7644 - BUG/MINOR: pools: use %u not %d to report pool stats in "show pools"
7645 - BUG/MINOR: pollers: remove uneeded free in global init
7646 - CLEANUP: select: enhance readability in init
7647 - BUG/MINOR: soft-stop: always wake up waiting threads on stopping
7648 - MINOR: soft-stop: let the first stopper only signal other threads
7649 - BUILD: select: only declare existing local labels to appease clang
7650 - BUG/MEDIUM: streams: Remove SF_ADDR_SET if we're retrying due to L7 retry.
7651 - BUG/MEDIUM: stream: Only allow L7 retries when using HTTP.
7652 - DOC: retry-on can only be used with mode http
7653 - MEDIUM: ssl: allow to register callbacks for SSL/TLS protocol messages
7654 - MEDIUM: ssl: split ssl_sock_msgcbk() and use a new callback mechanism
7655 - MINOR: ssl: add a new function ssl_sock_get_ssl_object()
7656 - MEDIUM: ssl: use ssl_sock_get_ssl_object() in fetchers where appropriate
7657 - REORG: ssl: move macros and structure definitions to ssl_sock.h
7658 - CLEANUP: ssl: remove the shsess_* macros
7659 - REORG: move the crt-list structures in their own .h
7660 - REORG: ssl: move the ckch structures to types/ssl_ckch.h
7661 - CLEANUP: ssl: add ckch prototypes in proto/ssl_ckch.h
7662 - REORG: ssl: move crtlist functions to src/ssl_crtlist.c
7663 - CLEANUP: ssl: avoid circular dependencies in ssl_crtlist.h
7664 - REORG: ssl: move the ckch_store related functions to src/ssl_ckch.c
7665 - REORG: ssl: move ckch_inst functions to src/ssl_ckch.c
7666 - REORG: ssl: move the crt-list CLI functions in src/ssl_crtlist.c
7667 - REORG: ssl: move the CLI 'cert' functions to src/ssl_ckch.c
7668 - REORG: ssl: move ssl configuration to cfgparse-ssl.c
7669 - MINOR: ssl: remove static keyword in some SSL utility functions
7670 - REORG: ssl: move ssl_sock_ctx and fix cross-dependencies issues
7671 - REORG: ssl: move sample fetches to src/ssl_sample.c
7672 - REORG: ssl: move utility functions to src/ssl_utils.c
7673 - DOC: ssl: update MAINTAINERS file
7674 - CI: travis-ci: switch arm64 builds to use openssl from distro
7675 - MINOR: stats: Prepare for more accurate moving averages
7676 - MINOR: stats: Expose native cum_req metric for a server
7677 - MEDIUM: stats: Enable more accurate moving average calculation for stats
7678 - BUILD: ssl: include buffer common headers for ssl_sock_ctx
7679 - BUILD: ssl: include errno.h in ssl_crtlist.c
7680 - CLEANUP: acl: remove unused assignment
7681 - DOC/MINOR: halog: Add long help info for ic flag
7682 - BUILD: ssl: fix build without OPENSSL_NO_ENGINE
7683 - DOC: SPOE is no longer experimental
7684 - BUG/MINOR: cache: Don't needlessly test "cache" keyword in parse_cache_flt()
7685 - MINOR: config: Don't dump keywords if argument is NULL
7686 - MEDIUM: checks: Make post-41 the default mode for mysql checks
7687 - BUG/MINOR: logs: prevent double line returns in some events.
7688 - MEDIUM: sink: build header in sink_write for log formats
7689 - MEDIUM: logs: buffer targets now rely on new sink_write
7690 - MEDIUM: sink: add global statement to create a new ring (sink buffer)
7691 - MEDIUM: hpack: use a pool for the hpack table
7692 - BUG/MAJOR: mux-fcgi: Stop sending loop if FCGI stream is blocked for any reason
7693 - BUG/MEDIUM: ring: write-lock the ring while attaching/detaching
7694 - MINOR: applet: adopt the wait list entry from the CLI
7695 - MINOR: ring: make the applet code not depend on the CLI
7696 - Revert "MEDIUM: sink: add global statement to create a new ring (sink buffer)"
7697 - CI: travis-ci: fix libslz download URL
7698 - MINOR: ssl: split config and runtime variable for ssl-{min,max}-ver
7699 - CLEANUP: http_ana: Remove unused TXN flags
7700 - BUG/MINOR: http-rules: Mark http return rules as final
7701 - MINOR: http-htx: Add http_reply type based on what is used for http return rules
7702 - CLEANUP: http-htx: Rename http_error structure into http_error_msg
7703 - MINOR: http-rules: Use http_reply structure for http return rules
7704 - MINOR: http-htx: Use a dedicated function to release http_reply objects
7705 - MINOR: http-htx: Use a dedicated function to parse http reply arguments
7706 - MINOR: http-htx: Use a dedicated function to check http reply validity
7707 - MINOR: http-ana: Use a dedicated function to send a response from an http reply
7708 - MEDIUM: http-rules: Rely on http reply for http deny/tarpit rules
7709 - MINOR: http-htx: Store default error messages in a global http reply array
7710 - MINOR: http-htx: Store messages of an http-errors section in a http reply array
7711 - MINOR: http-htx: Store errorloc/errorfile messages in http replies
7712 - MINOR: proxy: Add references on http replies for proxy error messages
7713 - MINOR: http-htx: Use http reply from the http-errors section
7714 - MINOR: http-ana: Use a TXN flag to prevent after-response ruleset evaluation
7715 - MEDIUM: http-ana: Use http replies for HTTP error messages
7716 - CLEANUP: http-htx: Remove unused storage of error messages in buffers
7717 - MINOR: htx: Add a function to copy a buffer in an HTX message
7718 - CLEANUP: channel: Remove channel_htx_copy_msg() function
7719 - MINOR: http-ana: Add a function to write an http reply in an HTX message
7720 - MINOR: http-htx/proxy: Add http-error directive using http return syntax
7721 - DOC: Fix "errorfile" description in the configuration manual
7722 - BUG/MINOR: checks: Respect check-ssl param when a port or an addr is specified
7723 - BUILD: hpack: make sure the hpack table can still be built standalone
7724 - CONTRIB: hpack: make use of the simplified standalone HPACK API
7725 - MINOR: connection: add pp2-never-send-local to support old PP2 behavior
7726
Willy Tarreaufc0b8f32020-05-05 21:49:10 +020077272020/05/05 : 2.2-dev7
7728 - MINOR: version: Show uname output in display_version()
7729 - CI: run weekly OpenSSL "no-deprecated" builds
7730 - CLEANUP: log: fix comment of parse_logformat_string()
7731 - DOC: Improve documentation on http-request set-src
7732 - MINOR: ssl/cli: disallow SSL options for directory in 'add ssl crt-list'
7733 - MINOR: ssl/cli: restrain certificate path when inserting into a directory
7734 - MINOR: ssl: add ssl-skip-self-issued-ca global option
7735 - BUG/MINOR: ssl: default settings for ssl server options are not used
7736 - MINOR: config: add a global directive to set default SSL curves
7737 - BUG/MEDIUM: http-ana: Handle NTLM messages correctly.
7738 - DOC: internals: update the SSL architecture schema
7739 - BUG/MINOR: tools: fix the i386 version of the div64_32 function
7740 - BUG/MINOR: mux-fcgi/trace: fix wrong set of trace flags in fcgi_strm_add_eom()
7741 - BUG/MINOR: http: make url_decode() optionally convert '+' to SP
7742 - DOC: option logasap does not depend on mode
7743 - MEDIUM: memory: make pool_gc() run under thread isolation
7744 - MINOR: contrib: make the peers wireshark dissector a plugin
7745 - BUG/MINOR: http-ana: Throw a 500 error if after-response ruleset fails on errors
7746 - BUG/MINOR: check: Update server address and port to execute an external check
7747 - MINOR: mini-clist: Add functions to iterate backward on a list
7748 - MINOR: checks: Add a way to send custom headers and payload during http chekcs
7749 - MINOR: server: respect warning and alert semantic
7750 - BUG/MINOR: checks: Respect the no-check-ssl option
7751 - BUG/MEDIUM: server/checks: Init server check during config validity check
7752 - CLEANUP: checks: Don't export anymore init_check and srv_check_healthcheck_port
7753 - BUG/MINOR: checks: chained expect will not properly wait for enough data
7754 - BUG/MINOR: checks: Forbid tcp-check lines in default section as documented
7755 - MINOR: checks: Use an enum to describe the tcp-check rule type
7756 - MINOR: checks: Simplify connection flag parsing in tcp-check connect
7757 - MEDIUM: checks: rewind to the first inverse expect rule of a chain on new data
7758 - MINOR: checks: simplify tcp expect config parser
7759 - MINOR: checks: add min-recv tcp-check expect option
7760 - MINOR: checks: add linger option to tcp connect
7761 - MINOR: checks: define a tcp expect type
7762 - MEDIUM: checks: rewrite tcp-check expect block
7763 - MINOR: checks: Stop xform buffers to null-terminated string for tcp-check rules
7764 - MINOR: checks: add rbinary expect match type
7765 - MINOR: checks: Simplify functions to get step id and comment
7766 - MEDIUM: checks: capture groups in expect regexes
7767 - MINOR: checks: Don't use a static tcp rule list head
7768 - MEDIUM: checks: Use a non-comment rule iterator to get next rule
7769 - MEDIUM: proxy/checks: Register a keyword to parse tcp-check rules
7770 - MINOR: checks: Set the tcp-check rule index during parsing
7771 - MINOR: checks: define tcp-check send type
7772 - MINOR: checks: define a tcp-check connect type
7773 - MEDIUM: checks: Add implicit tcp-check connect rule
7774 - MAJOR: checks: Refactor and simplify the tcp-check loop
7775 - MEDIUM: checks: Associate a session to each tcp-check healthcheck
7776 - MINOR: checks/vars: Add a check scope for variables
7777 - MEDIUM: checks: Parse custom action rules in tcp-checks
7778 - MINOR: checks: Add support to set-var and unset-var rules in tcp-checks
7779 - MINOR: checks: Add the sni option for tcp-check connect rules
7780 - MINOR: checks: Add the via-socks4 option for tcp-check connect rules
7781 - MINOR: checks: Add the alpn option for tcp-check connect rules
7782 - MINOR: ssl: Export a generic function to parse an alpn string
7783 - MINOR: checks: Add the default option for tcp-check connect rules
7784 - MINOR: checks: Add the addr option for tcp-check connect rule
7785 - MEDIUM: checks: Support expression to set the port
7786 - MEDIUM: checks: Support log-format strings for tcp-check send rules
7787 - MINOR: log: Don't depends on a stream to process samples in log-format string
7788 - MINOR: log: Don't systematically set LW_REQ when a sample expr is added
7789 - MEDIUM: checks: Add a shared list of tcp-check rules
7790 - MINOR: sample: add htonl converter
7791 - MINOR: sample: add cut_crlf converter
7792 - MINOR: sample: add ltrim converter
7793 - MINOR: sample: add rtrim converter
7794 - MINOR: checks: Use a name for the healthcheck status enum
7795 - MINOR: checks: Add option to tcp-check expect rules to customize error status
7796 - MINOR: checks: Merge tcp-check comment rules with the others at config parsing
7797 - MINOR: checks: Add a sample fetch to extract a block from the input check buffer
7798 - MEDIUM: checks: Add on-error/on-success option on tcp-check expect rules
7799 - MEDIUM: checks: Add status-code sample expression on tcp-check expect rules
7800 - MINOR: checks: Relax the default option for tcp-check connect rules
7801 - MEDIUM: checks: Add a list of vars to set before executing a tpc-check ruleset
7802 - MINOR: checks: Export the tcpcheck_eval_ret enum
7803 - MINOR: checks: Use dedicated function to handle onsuccess/onerror messages
7804 - MINOR: checks: Support custom functions to eval a tcp-check expect rules
7805 - MEDIUM: checks: Implement redis check using tcp-check rules
7806 - MEDIUM: checks: Implement ssl-hello check using tcp-check rules
7807 - MEDIUM: checks: Implement smtp check using tcp-check rules
7808 - MEDIUM: checks: Implement postgres check using tcp-check rules
7809 - MEDIUM: checks: Implement MySQL check using tcp-check rules
7810 - MEDIUM: checks: Implement LDAP check using tcp-check rules
7811 - MEDIUM: checks: Implement SPOP check using tcp-check rules
7812 - MINOR: server/checks: Move parsing of agent keywords in checks.c
7813 - MINOR: server/checks: Move parsing of server check keywords in checks.c
7814 - MEDIUM: checks: Implement agent check using tcp-check rules
7815 - REGTEST: Adapt regtests about checks to recent changes
7816 - MINOR: Produce tcp-check info message for pure tcp-check rules only
7817 - MINOR: checks: Add an option to set success status of tcp-check expect rules
7818 - MINOR: checks: Improve log message of tcp-checks on success
7819 - MINOR: proxy/checks: Move parsing of httpchk option in checks.c
7820 - MINOR: proxy/checks: Move parsing of tcp-check option in checks.c
7821 - MINOR: proxy/checks: Register a keyword to parse http-check rules
7822 - MINOR: proxy/checks: Move parsing of external-check option in checks.c
7823 - MINOR: proxy/checks: Register a keyword to parse external-check rules
7824 - MEDIUM: checks: Use a shared ruleset to store tcp-check rules
7825 - MINOR: checks: Use an indirect string to represent the expect matching string
7826 - MINOR: checks: Introduce flags to configure in tcp-check expect rules
7827 - MINOR: standard: Add my_memspn and my_memcspn
7828 - MINOR: checks: Add a reverse non-comment rule iterator to get last rule
7829 - MAJOR: checks: Implement HTTP check using tcp-check rules
7830 - MINOR: checks: Make resume conditions more explicit in tcpcheck_main()
7831 - MINOR: connection: Add macros to know if a conn or a cs uses an HTX mux
7832 - MEDIUM: checks: Refactor how data are received in tcpcheck_main()
7833 - MINOR: checks/obj_type: Add a new object type for checks
7834 - BUG/MINOR: obj_type: Handle stream object in obj_base_ptr() function
7835 - MINOR: checks: Use the check as origin when a session is created
7836 - MINOR: checks: Add a mux proto to health-check and tcp-check connect rule
7837 - MINOR: connection: Add a function to install a mux for a health-check
7838 - MAJOR: checks: Use the best mux depending on the protocol for health checks
7839 - MEDIUM: checks: Implement default TCP check using tcp-check rules
7840 - MINOR: checks: Remove unused code about pure TCP checks
7841 - CLEANUP: checks: Reorg checks.c file to be more readable
7842 - REGTEST: Fix reg-tests about health-checks to adapt them to recent changes
7843 - MINOR: ist: Add a function to retrieve the ist pointer
7844 - MINOR: checks: Use ist API as far as possible
7845 - BUG/MEDIUM: checks: Be sure to subscribe for sends if outgoing data remains
7846 - MINOR: checks: Use a tree instead of a list to store tcp-check rulesets
7847 - BUG/MINOR: checks: Send the right amount of outgoing data for HTTP checks
7848 - REGTEST: Add scripts to test based tcp-check health-checks
7849 - Revert "MEDIUM: checks: capture groups in expect regexes"
7850 - DOC: Add documentation about comments for tcp-check and http-check directives
7851 - DOC: Fix the tcp-check and http-check directives layout
7852 - BUG/MEDIUM: checks: Use the mux protocol specified on the server line
7853 - MINOR: checks: Support mux protocol definition for tcp and http health checks
7854 - BUG/MINOR: mux-fcgi: Be sure to have a connection as session's origin to use it
7855 - MINOR: checks: Support list of status codes on http-check expect rules
7856 - BUG/MEDIUM: checks: Unsubscribe to mux events when a conn-stream is destroyed
7857 - REGTEST: Add a script to validate agent checks
7858 - BUG/MINOR: server: Fix server_finalize_init() to avoid unused variable
7859 - BUG/MEDIUM: checks: unsubscribe for events on the old conn-stream on connect
7860 - BUG/MINOR: checks: Only use ssl_sock_is_ssl() if compiled with SSL support
7861 - BUG/MINOR: checks/server: use_ssl member must be signed
7862 - BUG/MEDIUM: sessions: Always pass the mux context as argument to destroy a mux
7863 - BUG/MEDIUM: checks: Destroy the conn-stream before the session
7864 - BUG/MINOR: checks: Fix PostgreSQL regex on the authentication packet
7865 - CI: cirrus-ci: remove reg-tests/checks/tcp-check-ssl.vtc on CentOS 6
7866 - MINOR: checks: Support HTTP/2 version (without '.0') for http-check send rules
7867 - MINOR: checks: Use ver keyword to specify the HTTP version for http checks
7868 - BUG/MINOR: checks: Remove wrong variable redeclaration
7869 - BUG/MINOR: checks: Properly handle truncated mysql server messages
7870 - CLEANUP: checks: Remove unused code when ldap server message is parsed
7871 - MINOR: checks: Make the use of the check's server more explicit on connect
7872 - BUG/MINOR: checks: Avoid incompatible cast when a binary string is parsed
7873 - BUG/MINOR: checks: Remove bad call to free() when an expect rule is parsed
7874 - BUG/MINOR: checks: Don't lose warning on proxy capability
7875 - MINOR: log: Add "Tu" timer
7876 - BUG/MINOR: checks: Set the output buffer length before calling parse_binary()
7877 - BUG/MEDIUM: mux-h1: make sure we always have a timeout on front connections
7878 - REGTEST: ssl: test the client certificate authentication
7879 - DOC: give a more accurate description of what check does
7880 - BUG/MEDIUM: capture: capture-req/capture-res converters crash without a stream
7881 - BUG/MEDIUM: capture: capture.{req,res}.* crash without a stream
7882 - BUG/MEDIUM: http: the "http_first_req" sample fetch could crash without a steeam
7883 - BUG/MEDIUM: http: the "unique-id" sample fetch could crash without a steeam
7884 - CLEANUP: http: add a few comments on certain functions' assumptions about streams
7885 - BUG/MEDIUM: sample: make the CPU and latency sample fetches check for a stream
7886 - MINOR: http-htx: Export functions to update message authority and host
7887 - MINOR: checks: Don't support multiple host header for http-check send rule
7888 - MINOR: checks: Skip some headers for http-check send rules
7889 - MINOR: checks: Keep the Host header and the request uri synchronized
7890 - CLEANUP: checks: Fix checks includes
7891 - DOC: Fix send rules in the http-check connect example
7892 - DOC: Add more info about request formatting in http-check send description
7893 - REGTEST: http-rules: Require PCRE or PCRE2 option to run map_redirect script
7894 - REGTEST: ssl: remove curl from the "add ssl crt-list" test
7895 - REGTEST: ssl: improve the "set ssl cert" test
7896 - CLEANUP: ssl: silence a build warning when threads are disabled
7897 - BUG/MEDIUM: listener: mark the thread as not stuck inside the loop
7898 - MINOR: threads: export the POSIX thread ID in panic dumps
7899 - BUG/MINOR: debug: properly use long long instead of long for the thread ID
7900 - BUG/MEDIUM: shctx: really check the lock's value while waiting
7901 - BUG/MEDIUM: shctx: bound the number of loops that can happen around the lock
7902 - MINOR: stream: report the list of active filters on stream crashes
7903 - BUG/MEDIUM: mux-fcgi: Return from detach if server don't keep the connection
7904 - BUG/MEDIUM: mux_fcgi: Free the FCGI connection at the end of fcgi_release()
7905 - BUG/MEDIUM: mux-fcgi: Fix wrong test on FCGI_CF_KEEP_CONN in fcgi_detach()
7906 - BUG/MEDIUM: connections: force connections cleanup on server changes
7907 - BUG/MEDIUM: h1: Don't compare host and authority if only h1 headers are parsed
7908 - BUG/MEDIUM: ssl: fix the id length check within smp_fetch_ssl_fc_session_id()
7909 - CLEANUP: connections: align function declaration
7910 - BUG/MINOR: sample: Set the correct type when a binary is converted to a string
7911 - MEDIUM: checks/http-fetch: Support htx prefetch from a check for HTTP samples
7912 - DOC: Document the log-format parameter for tcp-check send/send-binary rules
7913 - MINOR: checks: Add support of payload-based sample fetches
7914 - MINOR: checks: Add support of be_id, be_name, srv_id and srv_name sample fetches
7915 - MINOR: checks: Add support of server side ssl sample fetches
7916 - MINOR: checks: Add support of HTTP response sample fetches
7917 - MINOR: http-htx: Support different methods to look for header names
7918 - MINOR: checks: Set by default expect rule status to UNKNOWN during parsing
7919 - BUG/MINOR: checks: Support multiple HTTP expect rules
7920 - REGTEST: checks: Fix sync condition for agent-check
7921 - MEDIUM: checks: Support matching on headers for http-check expect rules
7922 - MINOR: lua: allow changing port with set_addr
7923 - BUG/MINOR: da: Fix HTX message prefetch
7924 - BUG/MINOR: wurfl: Fix HTX message prefetch
7925 - BUG/MINOR: 51d: Fix HTX message prefetch
7926 - MINOR: ist: add istadv() function
7927 - MINOR: ist: add istissame() function
7928 - MINOR: istbuf: add ist2buf() function
7929 - BUG/MINOR: threads: fix multiple use of argument inside HA_ATOMIC_CAS()
7930 - BUG/MINOR: threads: fix multiple use of argument inside HA_ATOMIC_UPDATE_{MIN,MAX}()
7931 - DOC: update intro.txt for 2.2
7932 - DOC: intro: add a contacts section
7933
Willy Tarreaud0089302020-04-17 14:19:38 +020079342020/04/17 : 2.2-dev6
7935 - BUG/MINOR: ssl: memory leak when find_chain is NULL
7936 - CLEANUP: ssl: rename ssl_get_issuer_chain to ssl_get0_issuer_chain
7937 - MINOR: ssl: rework add cert chain to CTX to be libssl independent
7938 - BUG/MINOR: peers: init bind_proc to 1 if it wasn't initialized
7939 - BUG/MINOR: peers: avoid an infinite loop with peers_fe is NULL
7940 - BUG/MINOR: peers: Use after free of "peers" section.
7941 - CI: github actions: add weekly h2spec test
7942 - BUG/MEDIUM: mux_h1: Process a new request if we already received it.
7943 - MINOR: build: Fix build in mux_h1
7944 - CLEANUP: remove obsolete comments
7945 - BUG/MEDIUM: dns: improper parsing of aditional records
7946 - MINOR: ssl: skip self issued CA in cert chain for ssl_ctx
7947 - MINOR: listener: add so_name sample fetch
7948 - MEDIUM: stream: support use-server rules with dynamic names
7949 - MINOR: servers: Add a counter for the number of currently used connections.
7950 - MEDIUM: connections: Revamp the way idle connections are killed
7951 - MINOR: cli: add a general purpose pointer in the CLI struct
7952 - MINOR: ssl: add a list of bind_conf in struct crtlist
7953 - REORG: ssl: move SETCERT enum to ssl_sock.h
7954 - BUG/MINOR: ssl: ckch_inst wrongly inserted in crtlist_entry
7955 - REORG: ssl: move some functions above crtlist_load_cert_dir()
7956 - MINOR: ssl: use crtlist_free() upon error in directory loading
7957 - MINOR: ssl: add a list of crtlist_entry in ckch_store
7958 - MINOR: ssl: store a ptr to crtlist in crtlist_entry
7959 - MINOR: ssl/cli: update pointer to store in 'commit ssl cert'
7960 - MEDIUM: ssl/cli: 'add ssl crt-list' command
7961 - REGTEST: ssl/cli: test the 'add ssl crt-list' command
7962 - BUG/MINOR: ssl: entry->ckch_inst not initialized
7963 - REGTEST: ssl/cli: change test type to devel
7964 - REGTEST: make the PROXY TLV validation depend on version 2.2
7965 - CLEANUP: assorted typo fixes in the code and comments
7966 - BUG/MINOR: stats: Fix color of draining servers on stats page
7967 - DOC: internals: Fix spelling errors in filters.txt
7968 - MINOR: connections: Don't mark conn flags 0x00000001 and 0x00000002 as unused.
7969 - REGTEST: make the unique-id test depend on version 2.0
7970 - BUG/MEDIUM: dns: Consider the fact that dns answers are case-insensitive
7971 - MINOR: ssl: split the line parsing of the crt-list
7972 - MINOR: ssl/cli: support filters and options in add ssl crt-list
7973 - MINOR: ssl: add a comment above the ssl_bind_conf keywords
7974 - REGTEST: ssl/cli: tests options and filters w/ add ssl crt-list
7975 - REGTEST: ssl: pollute the crt-list file
7976 - BUG/CRITICAL: hpack: never index a header into the headroom after wrapping
7977 - BUG/MINOR: protocol_buffer: Wrong maximum shifting.
7978 - CLEANUP: src/fd.c: mask setsockopt with DISGUISE
7979 - BUG/MINOR: ssl/cli: initialize fcount int crtlist_entry
7980 - REGTEST: ssl/cli: add other cases of 'add ssl crt-list'
7981 - CLEANUP: assorted typo fixes in the code and comments
7982 - DOC: management: add the new crt-list CLI commands
7983 - BUG/MINOR: ssl/cli: fix spaces in 'show ssl crt-list'
7984 - MINOR: ssl/cli: 'del ssl crt-list' delete an entry
7985 - MINOR: ssl/cli: replace dump/show ssl crt-list by '-n' option
7986 - CI: use better SSL library definition
7987 - CI: travis-ci: enable DEBUG_STRICT=1 for CI builds
7988 - CI: travis-ci: upgrade openssl to 1.1.1f
7989 - MINOR: ssl: improve the errors when a crt can't be open
7990 - CI: cirrus-ci: rename openssl package after it is renamed in FreeBSD
7991 - CI: adopt openssl download script to download all versions
7992 - BUG/MINOR: ssl/cli: lock the ckch structures during crt-list delete
7993 - MINOR: ssl/cli: improve error for bundle in add/del ssl crt-list
7994 - MINOR: ssl/cli: 'del ssl cert' deletes a certificate
7995 - BUG/MINOR: ssl: trailing slashes in directory names wrongly cached
7996 - BUG/MINOR: ssl/cli: memory leak in 'set ssl cert'
7997 - CLEANUP: ssl: use the refcount for the SSL_CTX'
7998 - CLEANUP: ssl/cli: use the list of filters in the crtlist_entry
7999 - BUG/MINOR: ssl: memleak of the struct cert_key_and_chain
8000 - CLEANUP: ssl: remove a commentary in struct ckch_inst
8001 - MINOR: ssl: initialize all list in ckch_inst_new()
8002 - MINOR: ssl: free instances and SNIs with ckch_inst_free()
8003 - MINOR: ssl: replace ckchs_free() by ckch_store_free()
8004 - BUG/MEDIUM: ssl/cli: trying to access to free'd memory
8005 - MINOR: ssl: ckch_store_new() alloc and init a ckch_store
8006 - MINOR: ssl: crtlist_new() alloc and initialize a struct crtlist
8007 - REORG: ssl: move some free/new functions
8008 - MINOR: ssl: crtlist_entry_{new, free}
8009 - BUG/MINOR: ssl: ssl_conf always set to NULL on crt-list parsing
8010 - MINOR: ssl: don't alloc ssl_conf if no option found
8011 - BUG/MINOR: connection: always send address-less LOCAL PROXY connections
8012 - BUG/MINOR: peers: Incomplete peers sections should be validated.
8013 - MINOR: init: report in "haproxy -c" whether there were warnings or not
8014 - MINOR: init: add -dW and "zero-warning" to reject configs with warnings
8015 - MINOR: init: report the compiler version in haproxy -vv
8016 - CLEANUP: assorted typo fixes in the code and comments
8017 - MINOR: init: report the haproxy version and executable path once on errors
8018 - DOC: Make how "option redispatch" works more explicit
8019 - BUILD: Makefile: add linux-musl to TARGET
8020 - CLEANUP: assorted typo fixes in the code and comments
8021 - CLEANUP: http: Fixed small typo in parse_http_return
8022 - DOC: hashing: update link to hashing functions
8023
Willy Tarreau3328f182020-03-23 09:43:45 +010080242020/03/23 : 2.2-dev5
8025 - CLEANUP: ssl: is_default is a bit in ckch_inst
8026 - BUG/MINOR: ssl/cli: sni_ctx' mustn't always be used as filters
8027 - DOC: ssl: clarify security implications of TLS tickets
8028 - CLEANUP: remove support for Linux i686 vsyscalls
8029 - CLEANUP: drop support for USE_MY_ACCEPT4
8030 - CLEANUP: remove support for USE_MY_EPOLL
8031 - CLEANUP: remove support for USE_MY_SPLICE
8032 - CLEANUP: remove the now unused common/syscall.h
8033 - BUILD: make dladdr1 depend on glibc version and not __USE_GNU
8034 - BUILD: wdt: only test for SI_TKILL when compiled with thread support
8035 - BUILD: Makefile: the compiler-specific flags should all be in SPEC_CFLAGS
8036 - CLEANUP: ssl: separate the directory loading in a new function
8037 - BUG/MINOR: buffers: MT_LIST_DEL_SAFE() expects the temporary pointer.
8038 - BUG/MEDIUM: mt_lists: Make sure we set the deleted element to NULL;
8039 - MINOR: init: move the maxsock calculation code to compute_ideal_maxsock()
8040 - MEDIUM: init: always try to push the FD limit when maxconn is set from -m
8041 - BUG/MAJOR: list: fix invalid element address calculation
8042 - BUILD: stream-int: fix a few includes dependencies
8043 - MINOR: mt_lists: Appease gcc.
8044 - MINOR: lists: Implement function to convert list => mt_list and mt_list => list
8045 - MINOR: servers: Kill priv_conns.
8046 - MINOR: lists: fix indentation.
8047 - BUG/MEDIUM: random: align the state on 2*64 bits for ARM64
8048 - BUG/MEDIUM: connections: Don't assume the connection has a valid session.
8049 - BUG/MEDIUM: pools: Always update free_list in pool_gc().
8050 - BUG/MINOR: haproxy: always initialize sleeping_thread_mask
8051 - BUG/MINOR: listener/mq: do not dispatch connections to remote threads when stopping
8052 - BUG/MINOR: haproxy/threads: try to make all threads leave together
8053 - Revert "BUILD: travis-ci: enable s390x builds"
8054 - BUILD: travis-ci: enable regular s390x builds
8055 - DOC: proxy_protocol: Reserve TLV type 0x05 as PP2_TYPE_UNIQUE_ID
8056 - MINOR: proxy_protocol: Ingest PP2_TYPE_UNIQUE_ID on incoming connections
8057 - MEDIUM: proxy_protocol: Support sending unique IDs using PPv2
8058 - CLEANUP: connection: Add blank line after declarations in PP handling
8059 - CLEANUP: assorted typo fixes in the code and comments
8060 - CI: add spellcheck github action
8061 - DOC: correct typo in alert message about rspirep
8062 - CI: travis: switch linux builds to clang-9
8063 - MINOR: debug: add a new DISGUISE() macro to pass a value as identity
8064 - MINOR: debug: consume the write() result in BUG_ON() to silence a warning
8065 - MINOR: use DISGUISE() everywhere we deliberately want to ignore a result
8066 - BUILD: pools: silence build warnings with DEBUG_MEMORY_POOLS and DEBUG_UAF
8067 - CLEANUP: connection: Stop directly setting an ist's .ptr
8068 - CI: travis: revert to clang-7 for BoringSSL tests
8069 - BUILD: on ARM, must be linked to libatomic.
8070 - BUILD: makefile: fix regex syntax in ARM platform detection
8071 - BUG/MEDIUM: peers: resync ended with RESYNC_PARTIAL in wrong cases.
8072 - REORG: ssl: move ssl_sock_load_cert()
8073 - MINOR: ssl: pass ckch_inst to ssl_sock_load_ckchs()
8074 - MEDIUM: ssl: allow crt-list caching
8075 - MINOR: ssl: directories are loaded like crt-list
8076 - BUG/MINOR: ssl: can't open directories anymore
8077 - BUG/MEDIUM: spoe: dup agent's engine_id string from trash.area
8078 - MINOR: fd: Use a separate lock for logs instead of abusing the fd lock.
8079 - MINOR: mux_pt: Don't try to remove the connection from the idle list.
8080 - MINOR: ssl/cli: show/dump ssl crt-list
8081 - BUG/MINOR: ssl/cli: free the trash chunk in dump_crtlist
8082 - MEDIUM: fd: Introduce a running mask, and use it instead of the spinlock.
8083 - BUG/MINOR: ssl: memory leak in crtlist_parse_file()
8084 - MINOR: tasks: Provide the tasklet to the callback.
8085 - BUG/MINOR: ssl: memleak of struct crtlist_entry
8086 - BUG/MINOR: pattern: Do not pass len = 0 to calloc()
8087 - BUILD: makefile: fix expression again to detect ARM platform
8088 - CI: travis: re-enable ASAN on clang
8089 - CI: travis: proper group output redirection together with travis_wait
8090 - DOC: assorted typo fixes in the documentation
8091 - MINOR: wdt: Move the definitions of WDTSIG and DEBUGSIG into types/signal.h.
8092 - BUG/MEDIUM: wdt: Don't ignore WDTSIG and DEBUGSIG in __signal_process_queue().
8093 - MINOR: memory: Change the flush_lock to a spinlock, and don't get it in alloc.
8094 - MINOR: ssl/cli: 'new ssl cert' command
8095 - MINOR: ssl/cli: show certificate status in 'show ssl cert'
8096 - MEDIUM: sessions: Don't be responsible for connections anymore.
8097 - MEDIUM: servers: Split the connections into idle, safe, and available.
8098 - MINOR: fd: Implement fd_takeover().
8099 - MINOR: connections: Add a new mux method, "takeover".
8100 - MINOR: connections: Make the "list" element a struct mt_list instead of list.
8101 - MINOR: connections: Add a flag to know if we're in the safe or idle list.
8102 - MEDIUM: connections: Attempt to get idle connections from other threads.
8103 - MEDIUM: mux_h1: Implement the takeover() method.
8104 - MEDIUM: mux_h2: Implement the takeover() method.
8105 - MEDIUM: mux_fcgi: Implement the takeover() method.
8106 - MEDIUM: connections: Kill connections even if we are reusing one.
8107 - BUG/MEDIUM: connections: Don't forget to decrement idle connection counters.
8108 - BUG/MINOR: ssl: Do not free garbage pointers on memory allocation failure
8109 - BUG/MINOR: ssl: Correctly add the 1 for the sentinel to the number of elements
8110 - BUG/MINOR: ssl: crtlist_dup_filters() must return NULL with fcount == 0
8111 - BUG/MEDIUM: build: Fix compilation by spelling decl correctly.
8112 - BUILD/MEDIUM: fd: Declare fd_mig_lock as extern.
8113 - CI: run travis-ci builds on push only, skip pull requests
8114 - CI: temporarily disable unstable travis arm64 builds
8115 - BUG/MINOR: ssl/cli: free BIO upon error in 'show ssl cert'
8116 - BUG/MINOR: connections: Make sure we free the connection on failure.
8117 - BUG/MINOR: ssl/cli: fix a potential NULL dereference
8118 - BUG/MEDIUM: h1: Make sure we subscribe before going into idle list.
8119 - BUG/MINOR: connections: Set idle_time before adding to idle list.
8120 - MINOR: muxes: Note that we can't usee a connection when added to the srv idle.
8121 - REGTEST: increase timeouts on the seamless-reload test
8122 - BUG/MINOR: haproxy/threads: close a possible race in soft-stop detection
8123 - CLEANUP: haproxy/threads: don't check global_tasks_mask twice
8124
Willy Tarreau5a753bd2020-03-09 14:57:20 +010081252020/03/09 : 2.2-dev4
8126 - MEDIUM: buffer: remove the buffer_wq lock
8127 - MINOR: ssl: move find certificate chain code to its own function
8128 - MINOR: ssl: resolve issuers chain later
8129 - MINOR: ssl: resolve ocsp_issuer later
8130 - MINOR: ssl/cli: "show ssl cert" command should print the "Chain Filename:"
8131 - BUG/MINOR: h2: reject again empty :path pseudo-headers
8132 - MINOR: wdt: always clear sigev_value to make valgrind happy
8133 - MINOR: epoll: always initialize all of epoll_event to please valgrind
8134 - BUG/MINOR: sample: Make sure to return stable IDs in the unique-id fetch
8135 - BUG/MEDIUM: ssl: chain must be initialized with sk_X509_new_null()
8136 - BUILD: cirrus-ci: suppress OS version check when installing packages
8137 - BUG/MINOR: http_ana: make sure redirect flags don't have overlapping bits
8138 - CLEANUP: fd: remove the FD_EV_STATUS aggregate
8139 - CLEANUP: fd: remove some unneeded definitions of FD_EV_* flags
8140 - MINOR: fd: merge the read and write error bits into RW error
8141 - BUG/MINOR: dns: ignore trailing dot
8142 - MINOR: contrib/prometheus-exporter: Add the last heathcheck duration metric
8143 - BUG/MINOR: http-htx: Do case-insensive comparisons on Host header name
8144 - MINOR: mux-h1: Remove useless case-insensitive comparisons
8145 - MINOR: rawsock: always mark the FD not ready when we're certain it happens
8146 - MEDIUM: connection: make the subscribe() call able to wakeup if ready
8147 - MEDIUM: connection: don't stop receiving events in the FD handler
8148 - MEDIUM: mux-h1: do not blindly wake up the tasklet at end of request anymore
8149 - BUG/MINOR: arg: don't reject missing optional args
8150 - MINOR: tools: make sure to correctly check the returned 'ms' in date2std_log
8151 - MINOR: debug: report the task handler's pointer relative to main
8152 - BUG/MEDIUM: debug: make the debug_handler check for the thread in threads_to_dump
8153 - MINOR: haproxy: export main to ease access from debugger
8154 - MINOR: haproxy: export run_poll_loop
8155 - MINOR: task: export run_tasks_from_list
8156 - BUILD: tools: remove obsolete and conflicting trace() from standard.c
8157 - MINOR: tools: add new function dump_addr_and_bytes()
8158 - MINOR: tools: add resolve_sym_name() to resolve function pointers
8159 - MINOR: debug: use resolve_sym_name() to dump task handlers
8160 - MINOR: cli: make "show fd" rely on resolve_sym_name()
8161 - MEDIUM: debug: add support for dumping backtraces of stuck threads
8162 - MINOR: debug: call backtrace() once upon startup
8163 - MINOR: ssl: add "ca-verify-file" directive
8164 - BUG/MINOR: wdt: do not return an error when the watchdog couldn't be enabled
8165 - BUILD: Makefile: include librt before libpthread
8166 - MEDIUM: wdt: fall back to CLOCK_REALTIME if CLOCK_THREAD_CPUTIME is not available
8167 - MINOR: wdt: do not depend on USE_THREAD
8168 - MINOR: debug: report the number of entries in the backtrace
8169 - MINOR: debug: improve backtrace() on aarch64 and possibly other systems
8170 - MINOR: debug: use our own backtrace function on clang+x86_64
8171 - MINOR: debug: dump the whole trace if we can't spot the starting point
8172 - BUILD: tools: unbreak resolve_sym_name() on non-GNU platforms
8173 - BUILD: tools: rely on __ELF__ not USE_DL to enable use of dladdr()
8174 - CLEANUP: contrib/spoa_example: Fix several typos
8175 - BUILD: makefile: do not modify the build options during make reg-tests
8176 - BUG/MEDIUM: connection: stop polling for sending when the event is ready
8177 - MEDIUM: stream-int: make sure to try to immediately validate the connection
8178 - MINOR: tcp/uxst/sockpair: only ask for I/O when really waiting for a connect()
8179 - MEDIUM: connection: only call ->wake() for connect() without I/O
8180 - OPTIM: connection: disable receiving on disabled events when the run queue is too high
8181 - OPTIM: mux-h1: subscribe rather than waking up at a few other places
8182 - REGTEST: Add unique-id reg-test
8183 - MINOR: stream: Add stream_generate_unique_id function
8184 - MINOR: stream: Use stream_generate_unique_id
8185 - BUG/MINOR: connection/debug: do not enforce !event_type on subscribe() anymore
8186 - MINOR: ssl/cli: support crt-list filters
8187 - MINOR: ssl: reach a ckch_store from a sni_ctx
8188 - DOC: fix incorrect indentation of http_auth_*
8189 - BUG/MINOR: ssl-sock: do not return an uninitialized pointer in ckch_inst_sni_ctx_to_sni_filters
8190 - MINOR: debug: add CLI command "debug dev write" to write an arbitrary size
8191 - MINOR: ist: Add `IST_NULL` macro
8192 - MINOR: ist: Add `int isttest(const struct ist)`
8193 - MINOR: ist: Add `struct ist istalloc(size_t)` and `void istfree(struct ist*)`
8194 - CLEANUP: Use `isttest()` and `istfree()`
8195 - MINOR: ist: Add `struct ist istdup(const struct ist)`
8196 - MINOR: proxy: Make `header_unique_id` a `struct ist`
8197 - MEDIUM: stream: Make the `unique_id` member of `struct stream` a `struct ist`
8198 - OPTIM: startup: fast unique_id allocation for acl.
8199 - DOC: configuration.txt: fix various typos
8200 - DOC: assorted typo fixes in the documentation and Makefile
8201 - BUG/MINOR: init: make the automatic maxconn consider the max of soft/hard limits
8202 - BUG/MAJOR: proxy_protocol: Properly validate TLV lengths
8203 - CLEANUP: proxy_protocol: Use `size_t` when parsing TLVs
8204 - MINOR: buf: Add function to insert a string at an absolute offset in a buffer
8205 - MINOR: htx: Add a function to return a block at a specific offset
8206 - MINOR: htx: Use htx_find_offset() to truncate an HTX message
8207 - MINOR: flt_trace: Use htx_find_offset() to get the available payload length
8208 - BUG/MINOR: filters: Use filter offset to decude the amount of forwarded data
8209 - BUG/MINOR: filters: Forward everything if no data filters are called
8210 - BUG/MEDIUM: cache/filters: Fix loop on HTX blocks caching the response payload
8211 - BUG/MEDIUM: compression/filters: Fix loop on HTX blocks compressing the payload
8212 - BUG/MINOR: http-ana: Reset request analysers on a response side error
8213 - BUG/MINOR: lua: Abort when txn:done() is called from a Lua action
8214 - BUG/MINOR: lua: Ignore the reserve to know if a channel is full or not
8215 - MINOR: lua: Add function to know if a channel is a response one
8216 - MINOR: lua: Stop using the lua txn in hlua_http_get_headers()
8217 - MINOR: lua: Stop using the lua txn in hlua_http_rep_hdr()
8218 - MINOR: lua: Stop using lua txn in hlua_http_del_hdr() and hlua_http_add_hdr()
8219 - MINOR: lua: Remove the flag HLUA_TXN_HTTP_RDY
8220 - MINOR: lua: Rename hlua_action_wake_time() to hlua_set_wake_time()
8221 - BUG/MINOR: lua: Init the lua wake_time value before calling a lua function
8222 - BUG/MINOR: http-rules: Return ACT_RET_ABRT to abort a transaction
8223 - BUG/MINOR: http-rules: Preserve FLT_END analyzers on reject action
8224 - BUG/MINOR: http-rules: Fix a typo in the reject action function
8225 - MINOR: cache/filters: Initialize the cache filter when stream is created
8226 - MINOR: compression/filters: Initialize the comp filter when stream is created
8227 - BUG/MINOR: rules: Preserve FLT_END analyzers on silent-drop action
8228 - BUG/MINOR: rules: Return ACT_RET_ABRT when a silent-drop action is executed
8229 - BUG/MINOR: rules: Increment be_counters if backend is assigned for a silent-drop
8230 - BUG/MINOR: http-rules: Abort transaction when a redirect is applied on response
8231 - BUILD: buffer: types/{ring.h,checks.h} should include buf.h, not buffer.h
8232 - BUILD: ssl: include mini-clist.h
8233 - BUILD: global: must not include common/standard.h but only types/freq_ctr.h
8234 - BUILD: freq_ctr: proto/freq_ctr needs to include common/standard.h
8235 - BUILD: listener: types/listener.h must not include standard.h
8236 - BUG/MEDIUM: random: initialize the random pool a bit better
8237 - BUG/MEDIUM: random: implement per-thread and per-process random sequences
8238 - Revert "BUG/MEDIUM: random: implement per-thread and per-process random sequences"
8239 - BUILD: cirrus-ci: get rid of unstable freebsd images
8240 - MINOR: tools: add 64-bit rotate operators
8241 - BUG/MEDIUM: random: implement a thread-safe and process-safe PRNG
8242 - MINOR: backend: use a single call to ha_random32() for the random LB algo
8243 - BUG/MINOR: checks/threads: use ha_random() and not rand()
8244 - MINOR: sample: make all bits random on the rand() sample fetch
8245 - MINOR: tools: add a generic function to generate UUIDs
8246 - DOC: fix typo about no-tls-tickets
8247 - DOC: improve description of no-tls-tickets
8248 - DOC: assorted typo fixes in the documentation
8249 - CLEANUP: remove unused code in 'my_ffsl/my_flsl' functions
8250
Willy Tarreau32bf97f2020-02-25 18:14:02 +010082512020/02/25 : 2.2-dev3
8252 - SCRIPTS: announce-release: place the send command in the mail's header
8253 - SCRIPTS: announce-release: allow the user to force to overwrite old files
8254 - SCRIPTS: backport: fix the master branch detection
8255 - BUG/MINOR: http-act: Set stream error flag before returning an error
8256 - BUG/MINOR: http-act: Fix bugs on error path during parsing of return actions
8257 - BUG/MEDIUM: ssl/cli: 'commit ssl cert' wrong SSL_CTX init
8258 - BUG/MEDIUM: tcp-rules: Fix track-sc* actions for L4/L5 TCP rules
8259 - DOC: schematic of the SSL certificates architecture
8260 - BUG/MAJOR: mux-h2: don't wake streams after connection was destroyed
8261 - BUG/MINOR: unix: better catch situations where the unix socket path length is close to the limit
8262 - BUILD: cirrus-ci: switch to "snap" images to unify openssl naming
8263 - BUILD: cirrus-ci: workaround "pkg install" bug
8264 - BUILD: cirrus-ci: add ERR=1 to freebsd builds
8265 - BUG/MINOR: connection: correctly retry I/O on signals
8266 - CLEANUP: mini-clist: simplify nested do { while(1) {} } while (0)
8267 - BUILD: http_act: cast file sizes when reporting file size error
8268 - BUG/MEDIUM: listener: only consider running threads when resuming listeners
8269 - BUG/MINOR: listener: enforce all_threads_mask on bind_thread on init
8270 - BUG/MINOR: tcp: avoid closing fd when socket failed in tcp_bind_listener
8271 - MINOR: build: add aix72-gcc build TARGET and power{8,9} CPUs
8272 - BUILD: travis-ci: no more allowed failures for openssl-1.0.2
8273 - BUILD: travis-ci: harden builds, add ERR=1 (warning ought to be errors)
8274 - BUILD: scripts/build-ssl.sh: use "uname" instead of ${TRAVIS_OS_NAME}
8275 - BUG/MINOR: tcp: don't try to set defaultmss when value is negative
8276 - SCRIPTS: make announce-release executable again
8277 - BUG/MINOR: namespace: avoid closing fd when socket failed in my_socketat
8278 - BUG/MEDIUM: muxes: Use the right argument when calling the destroy method.
8279 - BUG/MINOR: mux-fcgi: Forbid special characters when matching PATH_INFO param
8280 - CLEANUP: ssl: remove unused functions in openssl-compat.h
8281 - MINOR: mux-fcgi: Make the capture of the path-info optional in pathinfo regex
8282 - MINOR: tools: add is_idchar() to tell if a char may belong to an identifier
8283 - MINOR: chunk: implement chunk_strncpy() to copy partial strings
8284 - MINOR: sample/acl: use is_idchar() to locate the fetch/conv name
8285 - MEDIUM: arg: make make_arg_list() stop after its own arguments
8286 - MEDIUM: arg: copy parsed arguments into the trash instead of allocating them
8287 - MEDIUM: arg: make make_arg_list() support quotes in arguments
8288 - MINOR: sample: make sample_parse_expr() able to return an end pointer
8289 - MEDIUM: log-format: make the LF parser aware of sample expressions' end
8290 - BUG/MINOR: arg: report an error if an argument is larger than bufsize
8291 - SCRIPTS: announce-release: use mutt -H instead of -i to include the draft
8292 - BUILD: enable ERR=1 in github cygwin builds
8293 - BUG/MINOR: arg: fix again incorrect argument length check
8294 - MINOR: sample: regsub now supports backreferences
8295 - BUG/MINOR: tools: also accept '+' as a valid character in an identifier
8296 - MINOR: http-htx: Add a function to retrieve the headers size of an HTX message
8297 - MINOR: filters: Forward data only if the last filter forwards something
8298 - BUG/MINOR: filters: Count HTTP headers as filtered data but don't forward them
8299 - BUG/MINOR: http-htx: Don't return error if authority is updated without changes
8300 - BUG/MINOR: stream: Don't incr frontend cum_req counter when stream is closed
8301 - BUG/MINOR: sample: exit regsub() in case of trash allocation error
8302 - MINOR: ssl: add "issuers-chain-path" directive.
8303 - REGTESTS: use "command -v" instead of "which"
8304 - BUG/MINOR: http-ana: Matching on monitor-uri should be case-sensitive
8305 - MINOR: http-ana: Match on the path if the monitor-uri starts by a /
8306 - BUG/MINOR: ssl: Stop passing dynamic strings as format arguments
8307 - BUG/MAJOR: http-ana: Always abort the request when a tarpit is triggered
8308 - BUG/MINOR: mux: do not call conn_xprt_stop_recv() on buffer shortage
8309 - MINOR: checks: do not call conn_xprt_stop_send() anymore
8310 - CLEANUP: epoll: place the struct epoll_event in the stack
8311 - MEDIUM: connection: remove the intermediary polling state from the connection
8312 - MINOR: raw_sock: directly call fd_stop_send() and not conn_xprt_stop_send()
8313 - MINOR: tcp/uxst/sockpair: use fd_want_send() instead of conn_xprt_want_send()
8314 - MINOR: connection: remove the last calls to conn_xprt_{want,stop}_*
8315 - CLEANUP: connection: remove the definitions of conn_xprt_{stop,want}_{send,recv}
8316 - MINOR: connection: introduce a new receive flag: CO_RFL_READ_ONCE
8317 - MINOR: mux-h1: pass CO_RFL_READ_ONCE to the lower layers when relevant
8318 - MINOR: ist: add an iststop() function
8319 - BUG/MINOR: http: http-request replace-path duplicates the query string
8320 - CLEANUP: sample: use iststop instead of a for loop
8321 - BUG/MEDIUM: shctx: make sure to keep all blocks aligned
8322 - MINOR: compiler: move CPU capabilities definition from config.h and complete them
8323 - BUG/MEDIUM: ebtree: don't set attribute packed without unaligned access support
8324 - CLEANUP: http/h1: rely on HA_UNALIGNED_LE instead of checking for CPU families
8325 - BUILD: fix recent build failure on unaligned archs
8326 - MINOR: ssl: load the key from a dedicated file
8327 - BUG/MINOR: ssl: load .key in a directory only after PEM
8328 - MINOR: compiler: drop special cases of likely/unlikely for older compilers
8329 - CLEANUP: conn: Do not pass a pointer to likely
8330 - CLEANUP: net_helper: Do not negate the result of unlikely
8331 - BUILD: remove obsolete support for -mregparm / USE_REGPARM
8332 - CLEANUP: cfgparse: Fix type of second calloc() parameter
8333 - BUILD: ssl: only pass unsigned chars to isspace()
8334 - BUILD: general: always pass unsigned chars to is* functions
8335 - BUG/MINOR: sample: fix the json converter's endian-sensitivity
8336 - BUG/MEDIUM: ssl: fix several bad pointer aliases in a few sample fetch functions
8337 - CLEANUP: fd: use a union in fd_rm_from_fd_list() to shut aliasing warnings
8338 - CLEANUP: cache: use read_u32/write_u32 to access the cache entry's hash
8339 - CLEANUP: stick-tables: use read_u32() to display a node's key
8340 - CLEANUP: sample: use read_u64() in ipmask() to apply an IPv6 mask
8341 - MINOR: pattern: fix all remaining strict aliasing issues
8342 - CLEANUP: lua: fix aliasing issues in the address matching code
8343 - CLEANUP: connection: use read_u32() instead of a cast in the netscaler parser
8344 - BUILD: makefile: re-enable strict aliasing
8345 - BUG/MINOR: connection: make sure to correctly tag local PROXY connections
8346 - MINOR: compiler: add new alignment macros
8347 - BUILD: ebtree: improve architecture-specific alignment
8348 - MINOR: config: mark global.debug as deprecated
8349 - BUILD: travis-ci: enable s390x builds
8350 - MINOR: ssl/cli: 'show ssl cert' displays the chain
8351 - MINOR: ssl/cli: 'show ssl cert'displays the issuer in the chain
8352 - MINOR: ssl/cli: reorder 'show ssl cert' output
8353 - CLEANUP: ssl: move issuer_chain tree and definition
8354 - DOC: proxy-protocol: clarify IPv6 address representation in the spec
8355
Willy Tarreau4c47d912020-02-07 04:12:19 +010083562020/02/07 : 2.2-dev2
8357 - BUILD: CI: temporarily mark openssl-1.0.2 as allowed failure
8358 - MEDIUM: cli: Allow multiple filter entries for "show table"
8359 - BUG/MEDIUM: netscaler: Don't forget to allocate storage for conn->src/dst.
8360 - BUG/MINOR: ssl: ssl_sock_load_pem_into_ckch is not consistent
8361 - BUILD: stick-table: fix build errors introduced by last stick-table change
8362 - BUG/MINOR: cli: Missing arg offset for filter data values.
8363 - MEDIUM: streams: Always create a conn_stream in connect_server().
8364 - MEDIUM: connections: Get ride of the xprt_done callback.
8365 - CLEANUP: changelog: remove the duplicate entry for 2.2-dev1
8366 - BUILD: CI: move cygwin builds to Github Actions
8367 - MINOR: cli: Report location of errors or any extra data for "show table"
8368 - BUG/MINOR: ssl/cli: free the previous ckch content once a PEM is loaded
8369 - CLEANUP: backend: remove useless test for inexistent connection
8370 - CLEANUP: backend: shut another false null-deref in back_handle_st_con()
8371 - CLEANUP: stats: shut up a wrong null-deref warning from gcc 9.2
8372 - BUG/MINOR: ssl: increment issuer refcount if in chain
8373 - BUG/MINOR: ssl: memory leak w/ the ocsp_issuer
8374 - BUG/MINOR: ssl: typo in previous patch
8375 - BUG/MEDIUM: connections: Set CO_FL_CONNECTED in conn_complete_session().
8376 - BUG/MINOR: ssl/cli: ocsp_issuer must be set w/ "set ssl cert"
8377 - MEDIUM: connection: remove CO_FL_CONNECTED and only rely on CO_FL_WAIT_*
8378 - BUG/MEDIUM: 0rtt: Only consider the SSL handshake.
8379 - MINOR: stream-int: always report received shutdowns
8380 - MINOR: connection: remove CO_FL_SSL_WAIT_HS from CO_FL_HANDSHAKE
8381 - MEDIUM: connection: use CO_FL_WAIT_XPRT more consistently than L4/L6/HANDSHAKE
8382 - MINOR: connection: remove checks for CO_FL_HANDSHAKE before I/O
8383 - MINOR: connection: do not check for CO_FL_SOCK_RD_SH too early
8384 - MINOR: connection: don't check for CO_FL_SOCK_WR_SH too early in handshakes
8385 - MINOR: raw-sock: always check for CO_FL_SOCK_WR_SH before sending
8386 - MINOR: connection: remove some unneeded checks for CO_FL_SOCK_WR_SH
8387 - BUG/MINOR: stktable: report the current proxy name in error messages
8388 - BUG/MEDIUM: mux-h2: make sure we don't emit TE headers with anything but "trailers"
8389 - MINOR: lua: Add hlua_prepend_path function
8390 - MINOR: lua: Add lua-prepend-path configuration option
8391 - MINOR: lua: Add HLUA_PREPEND_C?PATH build option
8392 - BUILD: cfgparse: silence a bogus gcc warning on 32-bit machines
8393 - BUG/MINOR: http-ana: Increment the backend counters on the backend
8394 - BUG/MINOR: stream: Be sure to have a listener to increment its counters
8395 - BUG/MEDIUM: streams: Move the conn_stream allocation outside #IF USE_OPENSSL.
8396 - REGTESTS: make the set_ssl_cert test require version 2.2
8397 - BUG/MINOR: ssl: Possible memleak when allowing the 0RTT data buffer.
8398 - MINOR: ssl: Remove dead code.
8399 - BUG/MEDIUM: ssl: Don't forget to free ctx->ssl on failure.
8400 - BUG/MEDIUM: stream: Don't install the mux in back_handle_st_con().
8401 - MEDIUM: streams: Don't close the connection in back_handle_st_con().
8402 - MEDIUM: streams: Don't close the connection in back_handle_st_rdy().
8403 - BUILD: CI: disable slow regtests on Travis
8404 - BUG/MINOR: tcpchecks: fix the connect() flags regarding delayed ack
8405 - BUG/MINOR: http-rules: Always init log-format expr for common HTTP actions
8406 - BUG/MINOR: connection: fix ip6 dst_port copy in make_proxy_line_v2
8407 - BUG/MINOR: dns: allow 63 char in hostname
8408 - MINOR: proxy: clarify number of connections log when stopping
8409 - DOC: word converter ignores delimiters at the start or end of input string
8410 - MEDIUM: raw-sock: remove obsolete calls to fd_{cant,cond,done}_{send,recv}
8411 - BUG/MINOR: ssl/cli: fix unused variable with openssl < 1.0.2
8412 - MEDIUM: pipe/thread: reduce the locking overhead
8413 - MEDIUM: pipe/thread: maintain a per-thread local cache of recently used pipes
8414 - BUG/MEDIUM: pipe/thread: fix atomicity of pipe counters
8415 - MINOR: tasks: move the list walking code to its own function
8416 - MEDIUM: tasks: implement 3 different tasklet classes with their own queues
8417 - MEDIUM: tasks: automatically requeue into the bulk queue an already running tasklet
8418 - OPTIM: task: refine task classes default CPU bandwidth ratios
8419 - BUG/MEDIUM: connections: Don't forget to unlock when killing a connection.
8420 - MINOR: task: permanently flag tasklets waking themselves up
8421 - MINOR: task: make sched->current also reflect tasklets
8422 - MINOR: task: detect self-wakeups on tl==sched->current instead of TASK_RUNNING
8423 - OPTIM: task: readjust CPU bandwidth distribution since last update
8424 - MINOR: task: don't set TASK_RUNNING on tasklets
8425 - BUG/MEDIUM: memory_pool: Update the seq number in pool_flush().
8426 - MINOR: memory: Only init the pool spinlock once.
8427 - BUG/MEDIUM: memory: Add a rwlock before freeing memory.
8428 - BUG/MAJOR: memory: Don't forget to unlock the rwlock if the pool is empty.
8429 - MINOR: ssl: ssl-load-extra-files configure loading of files
8430 - SCRIPTS: add a new "backport" script to simplify long series of backports
8431 - BUG/MINOR: ssl: we may only ignore the first 64 errors
8432 - SCRIPTS: use /usr/bin/env bash instead of /bin/bash for scripts
8433 - BUG/MINOR: ssl: clear the SSL errors on DH loading failure
8434 - CLEANUP: hpack: remove a redundant test in the decoder
8435 - CLEANUP: peers: Remove unused static function `free_dcache`
8436 - CLEANUP: peers: Remove unused static function `free_dcache_tx`
8437 - CONTRIB: debug: add missing flags SF_HTX and SF_MUX
8438 - CONTRIB: debug: add the possibility to decode the value as certain types only
8439 - CONTRIB: debug: support reporting multiple values at once
8440 - BUG/MINOR: http-act: Use the good message to test strict rewritting mode
8441 - MINOR: global: Set default tune.maxrewrite value during global structure init
8442 - MINOR: http-rules: Set SF_ERR_PRXCOND termination flag when a header rewrite fails
8443 - MINOR: http-htx: Emit a warning if an error file runs over the buffer's reserve
8444 - MINOR: htx: Add a function to append an HTX message to another one
8445 - MINOR: htx/channel: Add a function to copy an HTX message in a channel's buffer
8446 - BUG/MINOR: http-ana: Don't overwrite outgoing data when an error is reported
8447 - MINOR: dns: Dynamically allocate dns options to reduce the act_rule size
8448 - MINOR: dns: Add function to release memory allocated for a do-resolve rule
8449 - BUG/MINOR: http-ana: Reset HTX first index when HAPRoxy sends a response
8450 - BUG/MINOR: http-ana: Set HTX_FL_PROXY_RESP flag if a server perform a redirect
8451 - MINOR: http-rules: Add a flag on redirect rules to know the rule direction
8452 - MINOR: http-rules: Handle the rule direction when a redirect is evaluated
8453 - MINOR: http-ana: Rely on http_reply_and_close() to handle server error
8454 - MINOR: http-ana: Add a function for forward internal responses
8455 - MINOR: http-ana/http-rules: Use dedicated function to forward internal responses
8456 - MEDIUM: http: Add a ruleset evaluated on all responses just before forwarding
8457 - MEDIUM: http-rules: Add the return action to HTTP rules
8458 - MEDIUM: http-rules: Support extra headers for HTTP return actions
8459 - CLEANUP: lua: Remove consistency check for sample fetches and actions
8460 - BUG/MINOR: http-ana: Increment failed_resp counters on invalid response
8461 - MINOR: lua: Get the action return code on the stack when an action finishes
8462 - MINOR: lua: Create the global 'act' object to register all action return codes
8463 - MINOR: lua: Add act:wake_time() function to set a timeout when an action yields
8464 - MEDIUM: lua: Add ability for actions to intercept HTTP messages
8465 - REGTESTS: Add reg tests for the HTTP return action
8466 - REGTESTS: Add a reg test for http-after-response rulesets
8467 - BUILD: lua: silence a warning on systems where longjmp is not marked as noreturn
8468 - MINOR: acl: Warn when an ACL is named 'or'
8469 - CONTRIB: debug: also support reading values from stdin
8470 - SCRIPTS: backport: use short revs and resolve the initial commit
8471 - BUG/MINOR: acl: Fix type of log message when an acl is named 'or'
8472
Willy Tarreau71f95fa2020-01-22 10:34:58 +010084732020/01/22 : 2.2-dev1
8474 - DOC: this is development again
8475 - MINOR: version: this is development again, update the status
8476 - SCRIPTS: update create-release to fix the changelog on new branches
8477 - CLEANUP: ssl: Clean up error handling
8478 - BUG/MINOR: contrib/prometheus-exporter: decode parameter and value only
8479 - BUG/MINOR: h1: Don't test the host header during response parsing
8480 - BUILD/MINOR: trace: fix use of long type in a few printf format strings
8481 - DOC: Clarify behavior of server maxconn in HTTP mode
8482 - MINOR: ssl: deduplicate ca-file
8483 - MINOR: ssl: compute ca-list from deduplicate ca-file
8484 - MINOR: ssl: deduplicate crl-file
8485 - CLEANUP: dns: resolution can never be null
8486 - BUG/MINOR: http-htx: Don't make http_find_header() fail if the value is empty
8487 - DOC: ssl/cli: set/commit/abort ssl cert
8488 - BUG/MINOR: ssl: fix SSL_CTX_set1_chain compatibility for openssl < 1.0.2
8489 - BUG/MINOR: fcgi-app: Make the directive pass-header case insensitive
8490 - BUG/MINOR: stats: Fix HTML output for the frontends heading
8491 - BUG/MINOR: ssl: fix X509 compatibility for openssl < 1.1.0
8492 - DOC: clarify matching strings on binary fetches
8493 - DOC: Fix ordered list in summary
8494 - DOC: move the "group" keyword at the right place
8495 - MEDIUM: init: prevent process and thread creation at runtime
8496 - BUG/MINOR: ssl/cli: 'ssl cert' cmd only usable w/ admin rights
8497 - BUG/MEDIUM: stream-int: don't subscribed for recv when we're trying to flush data
8498 - BUG/MINOR: stream-int: avoid calling rcv_buf() when splicing is still possible
8499 - BUG/MINOR: ssl/cli: don't overwrite the filters variable
8500 - BUG/MEDIUM: listener/thread: fix a race when pausing a listener
8501 - BUG/MINOR: ssl: certificate choice can be unexpected with openssl >= 1.1.1
8502 - BUG/MEDIUM: mux-h1: Never reuse H1 connection if a shutw is pending
8503 - BUG/MINOR: mux-h1: Don't rely on CO_FL_SOCK_RD_SH to set H1C_F_CS_SHUTDOWN
8504 - BUG/MINOR: mux-h1: Fix conditions to know whether or not we may receive data
8505 - BUG/MEDIUM: tasks: Make sure we switch wait queues in task_set_affinity().
8506 - BUG/MEDIUM: checks: Make sure we set the task affinity just before connecting.
8507 - MINOR: debug: replace popen() with pipe+fork() in "debug dev exec"
8508 - MEDIUM: init: set NO_NEW_PRIVS by default when supported
8509 - BUG/MINOR: mux-h1: Be sure to set CS_FL_WANT_ROOM when EOM can't be added
8510 - BUG/MEDIUM: mux-fcgi: Handle cases where the HTX EOM block cannot be inserted
8511 - BUG/MINOR: proxy: make soft_stop() also close FDs in LI_PAUSED state
8512 - BUG/MINOR: listener/threads: always use atomic ops to clear the FD events
8513 - BUG/MINOR: listener: also clear the error flag on a paused listener
8514 - BUG/MEDIUM: listener/threads: fix a remaining race in the listener's accept()
8515 - MINOR: listener: make the wait paths cleaner and more reliable
8516 - MINOR: listener: split dequeue_all_listener() in two
8517 - REORG: listener: move the global listener queue code to listener.c
8518 - DOC: document the listener state transitions
8519 - BUG/MEDIUM: kqueue: Make sure we report read events even when no data.
8520 - BUG/MAJOR: dns: add minimalist error processing on the Rx path
8521 - BUG/MEDIUM: proto_udp/threads: recv() and send() must not be exclusive.
8522 - DOC: listeners: add a few missing transitions
8523 - BUG/MINOR: tasks: only requeue a task if it was already in the queue
8524 - MINOR: tasks: split wake_expired_tasks() in two parts to avoid useless wakeups
8525 - DOC: proxies: HAProxy only supports 3 connection modes
8526 - DOC: remove references to the outdated architecture.txt
8527 - BUG/MINOR: log: fix minor resource leaks on logformat error path
8528 - BUG/MINOR: mworker: properly pass SIGTTOU/SIGTTIN to workers
8529 - BUG/MINOR: listener: do not immediately resume on transient error
8530 - BUG/MINOR: server: make "agent-addr" work on default-server line
8531 - BUG/MINOR: listener: fix off-by-one in state name check
8532 - BUILD/MINOR: unix sockets: silence an absurd gcc warning about strncpy()
8533 - MEDIUM: h1-htx: Add HTX EOM block when the message is in H1_MSG_DONE state
8534 - MINOR: http-htx: Add some htx sample fetches for debugging purpose
8535 - REGTEST: Add an HTX reg-test to check an edge case
8536 - DOC: clarify the fact that replace-uri works on a full URI
8537 - BUG/MINOR: sample: fix the closing bracket and LF in the debug converter
8538 - BUG/MINOR: sample: always check converters' arguments
8539 - MINOR: sample: Validate the number of bits for the sha2 converter
8540 - BUG/MEDIUM: ssl: Don't set the max early data we can receive too early.
8541 - MINOR: ssl/cli: 'show ssl cert' give information on the certificates
8542 - BUG/MINOR: ssl/cli: fix build for openssl < 1.0.2
8543 - MINOR: debug: support logging to various sinks
8544 - MINOR: http: add a new "replace-path" action
8545 - REGTEST: ssl: test the "set ssl cert" CLI command
8546 - REGTEST: run-regtests: implement #REQUIRE_BINARIES
8547 - MINOR: task: only check TASK_WOKEN_ANY to decide to requeue a task
8548 - BUG/MAJOR: task: add a new TASK_SHARED_WQ flag to fix foreing requeuing
8549 - BUG/MEDIUM: ssl: Revamp the way early data are handled.
8550 - MINOR: fd/threads: make _GET_NEXT()/_GET_PREV() use the volatile attribute
8551 - BUG/MEDIUM: fd/threads: fix a concurrency issue between add and rm on the same fd
8552 - REGTEST: make the "set ssl cert" require version 2.1
8553 - BUG/MINOR: ssl: openssl-compat: Fix getm_ defines
8554 - BUG/MEDIUM: state-file: do not allocate a full buffer for each server entry
8555 - BUG/MINOR: state-file: do not store duplicates in the global tree
8556 - BUG/MINOR: state-file: do not leak memory on parse errors
8557 - BUG/MAJOR: mux-h1: Don't pretend the input channel's buffer is full if empty
8558 - BUG/MEDIUM: stream: Be sure to never assign a TCP backend to an HTX stream
8559 - BUILD: ssl: improve SSL_CTX_set_ecdh_auto compatibility
8560 - BUILD: travis-ci: link with ssl libraries using rpath instead of LD_LIBRARY_PATH/DYLD_LIBRARY_PATH
8561 - BUILD: travis-ci: reenable address sanitizer for clang builds
8562 - BUG/MINOR: checks: refine which errno values are really errors.
8563 - BUG/MINOR: connection: only wake send/recv callbacks if the FD is active
8564 - CLEANUP: connection: conn->xprt is never NULL
8565 - MINOR: pollers: add a new flag to indicate pollers reporting ERR & HUP
8566 - MEDIUM: tcp: make tcp_connect_probe() consider ERR/HUP
8567 - REORG: connection: move tcp_connect_probe() to conn_fd_check()
8568 - MINOR: connection: check for connection validation earlier
8569 - MINOR: connection: remove the double test on xprt_done_cb()
8570 - CLEANUP: connection: merge CO_FL_NOTIFY_DATA and CO_FL_NOTIFY_DONE
8571 - MINOR: poller: do not call the IO handler if the FD is not active
8572 - OPTIM: epoll: always poll for recv if neither active nor ready
8573 - OPTIM: polling: do not create update entries for FD removal
8574 - BUG/MEDIUM: checks: Only attempt to do handshakes if the connection is ready.
8575 - BUG/MEDIUM: connections: Hold the lock when wanting to kill a connection.
8576 - BUILD: CI: modernize cirrus-ci
8577 - MINOR: config: disable busy polling on old processes
8578 - MINOR: ssl: Remove unused variable "need_out".
8579 - BUG/MINOR: h1: Report the right error position when a header value is invalid
8580 - BUG/MINOR: proxy: Fix input data copy when an error is captured
8581 - BUG/MEDIUM: http-ana: Truncate the response when a redirect rule is applied
8582 - BUG/MINOR: channel: inject output data at the end of output
8583 - BUG/MEDIUM: session: do not report a failure when rejecting a session
8584 - MEDIUM: dns: implement synchronous send
8585 - MINOR: raw_sock: make sure to disable polling once everything is sent
8586 - MINOR: http: Add 410 to http-request deny
8587 - MINOR: http: Add 404 to http-request deny
8588 - CLEANUP: mux-h2: remove unused goto "out_free_h2s"
8589 - BUILD: cirrus-ci: choose proper openssl package name
8590 - BUG/MAJOR: listener: do not schedule a task-less proxy
8591 - CLEANUP: server: remove unused err section in server_finalize_init
8592 - REGTEST: set_ssl_cert.vtc: replace "echo" with "printf"
8593 - BUG/MINOR: stream-int: Don't trigger L7 retry if max retries is already reached
8594 - BUG/MEDIUM: tasks: Use the MT macros in tasklet_free().
8595 - BUG/MINOR: mux-h2: use a safe list_for_each_entry in h2_send()
8596 - BUG/MEDIUM: mux-h2: fix missing test on sending_list in previous patch
8597 - CLEANUP: ssl: remove opendir call in ssl_sock_load_cert
8598 - MEDIUM: lua: don't call the GC as often when dealing with outgoing connections
8599 - BUG/MEDIUM: mux-h2: don't stop sending when crossing a buffer boundary
8600 - BUG/MINOR: cli/mworker: can't start haproxy with 2 programs
8601 - REGTEST: mcli/mcli_start_progs: start 2 programs
8602 - BUG/MEDIUM: mworker: remain in mworker mode during reload
8603 - DOC: clarify crt-base usage
8604 - CLEANUP: compression: remove unused deinit_comp_ctx section
8605 - BUG/MEDIUM: mux_h1: Don't call h1_send if we subscribed().
8606 - BUG/MEDIUM: raw_sock: Make sur the fd and conn are sync.
8607 - CLEANUP: proxy: simplify proxy_parse_rate_limit proxy checks
8608 - BUG/MAJOR: hashes: fix the signedness of the hash inputs
8609 - REGTEST: add sample_fetches/hashes.vtc to validate hashes
8610 - BUG/MEDIUM: cli: _getsocks must send the peers sockets
8611 - CLEANUP: cli: deduplicate the code in _getsocks
8612 - BUG/MINOR: stream: don't mistake match rules for store-request rules
8613 - BUG/MEDIUM: connection: add a mux flag to indicate splice usability
8614 - BUG/MINOR: pattern: handle errors from fgets when trying to load patterns
8615 - MINOR: connection: move the CO_FL_WAIT_ROOM cleanup to the reader only
8616 - MINOR: stream-int: remove dependency on CO_FL_WAIT_ROOM for rcv_buf()
8617 - MEDIUM: connection: get rid of CO_FL_CURR_* flags
8618 - BUILD: pattern: include errno.h
8619 - MEDIUM: mux-h2: do not try to stop sending streams on blocked mux
8620 - MEDIUM: mux-fcgi: do not try to stop sending streams on blocked mux
8621 - MEDIUM: mux-h2: do not make an h2s subscribe to itself on deferred shut
8622 - MEDIUM: mux-fcgi: do not make an fstrm subscribe to itself on deferred shut
8623 - REORG: stream/backend: move backend-specific stuff to backend.c
8624 - MEDIUM: backend: move the connection finalization step to back_handle_st_con()
8625 - MEDIUM: connection: merge the send_wait and recv_wait entries
8626 - MEDIUM: xprt: merge recv_wait and send_wait in xprt_handshake
8627 - MEDIUM: ssl: merge recv_wait and send_wait in ssl_sock
8628 - MEDIUM: mux-h1: merge recv_wait and send_wait
8629 - MEDIUM: mux-h2: merge recv_wait and send_wait event notifications
8630 - MEDIUM: mux-fcgi: merge recv_wait and send_wait event notifications
8631 - MINOR: connection: make the last arg of subscribe() a struct wait_event*
8632 - MINOR: ssl: Add support for returning the dn samples from ssl_(c|f)_(i|s)_dn in LDAP v3 (RFC2253) format.
8633 - DOC: Fix copy and paste mistake in http-response replace-value doc
8634 - BUG/MINOR: cache: Fix leak of cache name in error path
8635 - BUG/MINOR: dns: Make dns_query_id_seed unsigned
8636 - BUG/MINOR: 51d: Fix bug when HTX is enabled
8637 - MINOR: http-htx: Move htx sample fetches in the scope "internal"
8638 - MINOR: http-htx: Rename 'internal.htx_blk.val' to 'internal.htx_blk.data'
8639 - MINOR: http-htx: Make 'internal.htx_blk_data' return a binary string
8640 - DOC: Add a section to document the internal sample fetches
8641 - MINOR: mux-h1: Inherit send flags from the upper layer
8642 - MINOR: contrib/prometheus-exporter: Add heathcheck status/code in server metrics
8643 - BUG/MINOR: http-ana/filters: Wait end of the http_end callback for all filters
8644 - BUG/MINOR: http-rules: Remove buggy deinit functions for HTTP rules
8645 - BUG/MINOR: stick-table: Use MAX_SESS_STKCTR as the max track ID during parsing
8646 - MEDIUM: http-rules: Register an action keyword for all http rules
8647 - MINOR: tcp-rules: Always set from which ruleset a rule comes from
8648 - MINOR: actions: Use ACT_RET_CONT code to ignore an error from a custom action
8649 - MINOR: tcp-rules: Kill connections when custom actions return ACT_RET_ERR
8650 - MINOR: http-rules: Return an error when custom actions return ACT_RET_ERR
8651 - MINOR: counters: Add a counter to report internal processing errors
8652 - MEDIUM: http-ana: Properly handle internal processing errors
8653 - MINOR: http-rules: Add a rule result to report internal error
8654 - MINOR: http-rules: Handle internal errors during HTTP rules evaluation
8655 - MINOR: http-rules: Add more return codes to let custom actions act as normal ones
8656 - MINOR: tcp-rules: Handle denied/aborted/invalid connections from TCP rules
8657 - MINOR: http-rules: Handle denied/aborted/invalid connections from HTTP rules
8658 - MINOR: stats: Report internal errors in the proxies/listeners/servers stats
8659 - MINOR: contrib/prometheus-exporter: Export internal errors per proxy/server
8660 - MINOR: counters: Remove failed_secu counter and use denied_resp instead
8661 - MINOR: counters: Review conditions to increment counters from analysers
8662 - MINOR: http-ana: Add a txn flag to support soft/strict message rewrites
8663 - MINOR: http-rules: Handle all message rewrites the same way
8664 - MINOR: http-rules: Add a rule to enable or disable the strict rewriting mode
8665 - MEDIUM: http-rules: Enable the strict rewriting mode by default
8666 - REGTEST: Fix format of set-uri HTTP request rule in h1or2_to_h1c.vtc
8667 - MINOR: actions: Add a function pointer to release args used by actions
8668 - MINOR: actions: Regroup some info about HTTP rules in the same struct
8669 - MINOR: http-rules/tcp-rules: Call the defined action function first if defined
8670 - MINOR: actions: Rename the act_flag enum into act_opt
8671 - MINOR: actions: Add flags to configure the action behaviour
8672 - MINOR: actions: Use an integer to set the action type
8673 - MINOR: http-rules: Use a specific action type for some custom HTTP actions
8674 - MINOR: http-rules: Make replace-header and replace-value custom actions
8675 - MINOR: http-rules: Make set-header and add-header custom actions
8676 - MINOR: http-rules: Make set/del-map and add/del-acl custom actions
8677 - MINOR: http-rules: Group all processing of early-hint rule in its case clause
8678 - MEDIUM: http-rules: Make early-hint custom actions
8679 - MINOR: http-rule/tcp-rules: Make track-sc* custom actions
8680 - MINOR: tcp-rules: Make tcp-request capture a custom action
8681 - MINOR: http-rules: Add release functions for existing HTTP actions
8682 - BUG/MINOR: http-rules: Fix memory releases on error path during action parsing
8683 - MINOR: tcp-rules: Add release functions for existing TCP actions
8684 - BUG/MINOR: tcp-rules: Fix memory releases on error path during action parsing
8685 - MINOR: http-htx: Add functions to read a raw error file and convert it in HTX
8686 - MINOR: http-htx: Add functions to create HTX redirect message
8687 - MINOR: config: Use dedicated function to parse proxy's errorfiles
8688 - MINOR: config: Use dedicated function to parse proxy's errorloc
8689 - MEDIUM: http-htx/proxy: Use a global and centralized storage for HTTP error messages
8690 - MINOR: proxy: Register keywords to parse errorfile and errorloc directives
8691 - MINOR: http-htx: Add a new section to create groups of custom HTTP errors
8692 - MEDIUM: proxy: Add a directive to reference an http-errors section in a proxy
8693 - MINOR: http-rules: Update txn flags and status when a deny rule is executed
8694 - MINOR: http-rules: Support an optional status on deny rules for http reponses
8695 - MINOR: http-rules: Use same function to parse request and response deny actions
8696 - MINOR: http-ana: Add an error message in the txn and send it when defined
8697 - MEDIUM: http-rules: Support an optional error message in http deny rules
8698 - REGTEST: Add a strict rewriting mode reg test
8699 - REGEST: Add reg tests about error files
8700 - MINOR: ssl: accept 'verify' bind option with 'set ssl cert'
8701 - BUG/MINOR: ssl: ssl_sock_load_ocsp_response_from_file memory leak
8702 - BUG/MINOR: ssl: ssl_sock_load_issuer_file_into_ckch memory leak
8703 - BUG/MINOR: ssl: ssl_sock_load_sctl_from_file memory leak
8704 - BUG/MINOR: http_htx: Fix some leaks on error path when error files are loaded
8705 - CLEANUP: http-ana: Remove useless test on txn when the error message is retrieved
8706 - BUILD: CI: introduce ARM64 builds
8707 - BUILD: ssl: more elegant anti-replay feature presence check
8708 - MINOR: proxy/http-ana: Add support of extra attributes for the cookie directive
8709 - MEDIUM: dns: use Additional records from SRV responses
8710 - CLEANUP: Consistently `unsigned int` for bitfields
8711 - CLEANUP: pattern: remove the pat_time definition
8712 - BUG/MINOR: http_act: don't check capture id in backend
8713 - BUG/MINOR: ssl: fix build on development versions of openssl-1.1.x
8714
Willy Tarreau2e077f82019-11-25 20:36:16 +010087152019/11/25 : 2.2-dev0
8716 - exact copy of 2.1.0
8717
Willy Tarreaue54b43a2019-11-25 19:47:40 +010087182019/11/25 : 2.1.0
8719 - BUG/MINOR: init: fix set-dumpable when using uid/gid
8720 - MINOR: init: avoid code duplication while setting identify
8721 - BUG/MINOR: ssl: ssl_pkey_info_index ex_data can store a dereferenced pointer
8722 - BUG/MINOR: ssl: fix crt-list neg filter for openssl < 1.1.1
8723 - MINOR: peers: Alway show the table info for disconnected peers.
8724 - MINOR: peers: Add TX/RX heartbeat counters.
8725 - MINOR: peers: Add debugging information to "show peers".
8726 - BUG/MINOR: peers: Wrong null "server_name" data field handling.
8727 - MINOR: ssl/cli: 'abort ssl cert' deletes an on-going transaction
8728 - BUG/MEDIUM: mworker: don't fill the -sf argument with -1 during the reexec
8729 - BUG/MINOR: peers: "peer alive" flag not reset when deconnecting.
8730 - BUILD/MINOR: ssl: fix compiler warning about useless statement
8731 - BUG/MEDIUM: stream-int: Don't loose events on the CS when an EOS is reported
8732 - MINOR: contrib/prometheus-exporter: filter exported metrics by scope
8733 - MINOR: contrib/prometheus-exporter: Add a param to ignore servers in maintenance
8734 - BUILD: debug: Avoid warnings in dev mode with -02 because of some BUG_ON tests
8735 - BUG/MINOR: mux-h1: Fix tunnel mode detection on the response path
8736 - BUG/MINOR: http-ana: Properly catch aborts during the payload forwarding
8737 - DOC: Update http-buffer-request description to remove the part about chunks
8738 - BUG/MINOR: stream-int: Fix si_cs_recv() return value
8739 - DOC: internal: document the init calls
8740 - MEDIUM: dns: Add resolve-opts "ignore-weight"
8741 - MINOR: ssl: ssl_sock_prepare_ctx() return an error code
8742 - MEDIUM: ssl/cli: apply SSL configuration on SSL_CTX during commit
8743 - MINOR: ssl/cli: display warning during 'commit ssl cert'
8744 - MINOR: version: report the version status in "haproxy -v"
8745 - MINOR: version: emit the link to the known bugs in output of "haproxy -v"
8746 - DOC: Add documentation about the use-service action
8747 - MINOR: ssl: fix possible null dereference in error handling
8748 - BUG/MINOR: ssl: fix curve setup with LibreSSL
8749 - BUG/MINOR: ssl: Stop passing dynamic strings as format arguments
8750 - CLEANUP: ssl: check if a transaction exists once before setting it
8751 - BUG/MINOR: cli: fix out of bounds in -S parser
8752 - MINOR: ist: add ist_find_ctl()
8753 - BUG/MAJOR: h2: reject header values containing invalid chars
8754 - BUG/MAJOR: h2: make header field name filtering stronger
8755 - BUG/MAJOR: mux-h2: don't try to decode a response HEADERS frame in idle state
8756 - MINOR: h2: add a function to report H2 error codes as strings
8757 - MINOR: mux-h2/trace: report the connection and/or stream error code
8758 - SCRIPTS: create-release: show the correct origin name in suggested commands
8759 - SCRIPTS: git-show-backports: add "-s" to proposed cherry-pick commands
8760 - BUG/MEDIUM: trace: fix a typo causing an incorrect startup error
8761 - BUILD: reorder the objects in the makefile
8762 - DOC: mention in INSTALL haproxy 2.1 is a stable stable version
8763 - MINOR: version: indicate that this version is stable
8764
Willy Tarreau84681322019-11-15 18:49:37 +010087652019/11/15 : 2.1-dev5
8766 - BUG/MEDIUM: ssl/cli: don't alloc path when cert not found
8767 - BUG/MINOR: ssl/cli: unable to update a certificate without bundle extension
8768 - BUG/MINOR: ssl/cli: fix an error when a file is not found
8769 - MINOR: ssl/cli: replace the default_ctx during 'commit ssl cert'
8770 - DOC: fix date and http_date keywords syntax
8771 - MINOR: peers: Add "log" directive to "peers" section.
8772 - BUG/MEDIUM: mux-h1: Disable splicing for chunked messages
8773 - BUG/MEDIUM: stream: Be sure to support splicing at the mux level to enable it
8774 - MINOR: flt_trace: Rename macros to print trace messages
8775 - MINOR: trace: Add a set of macros to trace events if HA is compiled with debug
8776 - MEDIUM: stream/trace: Register a new trace source with its events
8777 - MINOR: doc: http-reuse connection pool fix
8778 - BUG/MEDIUM: stream: Be sure to release allocated captures for TCP streams
8779 - MINOR: http-ana: Remove the unused function http_reset_txn()
8780 - BUG/MINOR: action: do-resolve now use cached response
8781 - BUG: dns: timeout resolve not applied for valid resolutions
8782 - DOC: management: fix typo on "cache_lookups" stats output
8783 - BUG/MINOR: stream: init variables when the list is empty
8784 - BUG/MEDIUM: tasks: Make tasklet_remove_from_tasklet_list() no matter the tasklet.
8785 - BUG/MINOR: queue/threads: make the queue unlinking atomic
8786 - BUG/MEDIUM: Make sure we leave the session list in session_free().
8787 - CLEANUP: session: slightly simplify idle connection cleanup logic
8788 - MINOR: memory: also poison the area on freeing
8789 - CLEANUP: cli: use srv_shutdown_streams() instead of open-coding it
8790 - CLEANUP: stats: use srv_shutdown_streams() instead of open-coding it
8791 - BUG/MEDIUM: listeners: always pause a listener on out-of-resource condition
8792 - BUILD: contrib/da: remove an "unused" warning
8793 - BUG/MEDIUM: filters: Don't call TCP callbacks for HTX streams
8794 - MEDIUM: filters: Adapt filters API to allow again TCP filtering on HTX streams
8795 - MINOR: freq_ctr: Make the sliding window sums thread-safe
8796 - MINOR: stream: Remove the lock on the proxy to update time stats
8797 - MINOR: counters: Add fields to store the max observed for {q,c,d,t}_time
8798 - MINOR: stats: Report max times in addition of the averages for sessions
8799 - MINOR: contrib/prometheus-exporter: Report metrics about max times for sessions
8800 - BUG/MINOR: contrib/prometheus-exporter: Rename some metrics
8801 - MINOR: contrib/prometheus-exporter: report the number of idle conns per server
8802 - DOC: Add missing stats fields in the management manual
8803 - BUG/MINOR: mux-h1: Properly catch parsing errors on payload and trailers
8804 - BUG/MINOR: mux-h1: Don't set CS_FL_EOS on a read0 when receiving data to pipe
8805 - MINOR: mux-h1: Set EOI on the conn-stream when EOS is reported in TUNNEL state
8806 - MINOR: sink: Set the default max length for a message to BUFSIZE
8807 - MINOR: ring: make the parse function automatically set the handler/release
8808 - BUG/MINOR: log: make "show startup-log" use a ring buffer instead
8809 - MINOR: stick-table: allow sc-set-gpt0 to set value from an expression
8810
Willy Tarreau1753cb52019-11-03 15:43:10 +010088112019/11/03 : 2.1-dev4
8812 - BUG/MINOR: cli: don't call the kw->io_release if kw->parse failed
8813 - BUG/MINOR: mux-h2: Don't pretend mux buffers aren't full anymore if nothing sent
8814 - BUG/MAJOR: stream-int: Don't receive data from mux until SI_ST_EST is reached
8815 - DOC: remove obsolete section about header manipulation
8816 - BUG/MINOR: ssl/cli: cleanup on cli_parse_set_cert error
8817 - MINOR: ssl/cli: rework the 'set ssl cert' IO handler
8818 - BUILD: CI: comment out cygwin build, upgrade various ssl libraries
8819 - DOC: Improve documentation of http-re(quest|sponse) replace-(header|value|uri)
8820 - BUILD/MINOR: tools: shut up the format truncation warning in get_gmt_offset()
8821 - BUG/MINOR: spoe: fix off-by-one length in UUID format string
8822 - BUILD/MINOR: ssl: shut up a build warning about format truncation
8823 - BUILD: do not disable -Wformat-truncation anymore
8824 - MINOR: chunk: add chunk_istcat() to concatenate an ist after a chunk
8825 - Revert "MINOR: istbuf: add b_fromist() to make a buffer from an ist"
8826 - MINOR: mux: Add a new method to get informations about a mux.
8827 - BUG/MEDIUM: stream_interface: Only use SI_ST_RDY when the mux is ready.
8828 - BUG/MEDIUM: servers: Only set SF_SRV_REUSED if the connection if fully ready.
8829 - MINOR: doc: fix busy-polling performance reference
8830 - MINOR: config: allow no set-dumpable config option
8831 - MINOR: init: always fail when setrlimit fails
8832 - MINOR: ssl/cli: rework 'set ssl cert' as 'set/commit'
8833 - CLEANUP: ssl/cli: remove leftovers of bundle/certs (it < 2)
8834 - REGTEST: vtest can now enable mcli with its own flag
8835 - BUG/MINOR: config: Update cookie domain warn to RFC6265
8836 - MINOR: sample: add us/ms support to date/http_date
8837 - BUG/MINOR: ssl/cli: check trash allocation in cli_io_handler_commit_cert()
8838 - BUG/MEDIUM: mux-h2: report no available stream on a connection having errors
8839 - BUG/MEDIUM: mux-h2: immediately remove a failed connection from the idle list
8840 - BUG/MEDIUM: mux-h2: immediately report connection errors on streams
8841 - BUG/MINOR: stats: properly check the path and not the whole URI
8842 - BUG/MINOR: ssl: segfault in cli_parse_set_cert with old openssl/boringssl
8843 - BUG/MINOR: ssl: ckch->chain must be initialized
8844 - BUG/MINOR: ssl: double free on error for ckch->{key,cert}
8845 - MINOR: ssl: BoringSSL ocsp_response does not need issuer
8846 - BUG/MEDIUM: ssl/cli: fix dot research in cli_parse_set_cert
8847 - MINOR: backend: Add srv_name sample fetche
8848 - DOC: Add GitHub issue config.yml
8849
Willy Tarreauc70df532019-10-25 15:48:53 +020088502019/10/25 : 2.1-dev3
8851 - MINOR: mux-h2/trace: missing conn pointer in demux full message
8852 - MINOR: mux-h2: add a per-connection list of blocked streams
8853 - BUILD: ebtree: make eb_is_empty() and eb_is_dup() take a const
8854 - BUG/MEDIUM: mux-h2: do not enforce timeout on long connections
8855 - BUG/MEDIUM: tasks: Don't forget to decrement tasks_run_queue.
8856 - BUG/MINOR: peers: crash on reload without local peer.
8857 - BUG/MINOR: mux-h2/trace: Fix traces on h2c initialization
8858 - MINOR: h1-htx: Update h1_copy_msg_data() to ease the traces in the mux-h1
8859 - MINOR: htx: Adapt htx_dump() to be used from traces
8860 - MINOR: mux-h1/trace: register a new trace source with its events
8861 - MINOR: proxy: Store http-send-name-header in lower case
8862 - MINOR: http: Remove headers matching the name of http-send-name-header option
8863 - BUG/MINOR: mux-h1: Adjust header case when the server name is add to a request
8864 - BUG/MINOR: mux-h1: Adjust header case when chunked encoding is add to a message
8865 - MINOR: mux-h1: Try to wakeup the stream on output buffer allocation
8866 - MINOR: fcgi: Add function to get the string representation of a record type
8867 - MINOR: mux-fcgi/trace: Register a new trace source with its events
8868 - BUG/MEDIUM: cache: make sure not to cache requests with absolute-uri
8869 - DOC: clarify some points around http-send-name-header's behavior
8870 - MEDIUM: mux-h2: support emitting CONTINUATION frames after HEADERS
8871 - BUG/MINOR: mux-h1/mux-fcgi/trace: Fix position of the 4th arg in some traces
8872 - DOC: fix typo in Prometheus exporter doc
8873 - MINOR: h2: clarify the rules for how to convert an H2 request to HTX
8874 - MINOR: htx: Add 2 flags on the start-line to have more info about the uri
8875 - MINOR: http: Add a function to get the authority into a URI
8876 - MINOR: h1-htx: Set the flag HTX_SL_F_HAS_AUTHORITY during the request parsing
8877 - MEDIUM: http-htx: Keep the Host header and the request start-line synchronized
8878 - MINOR: h1-htx: Only use the path of a normalized URI to format a request line
8879 - MEDIUM: h2: make the request parser rebuild a complete URI
8880 - MINOR: h2: report in the HTX flags when the request has an authority
8881 - MEDIUM: mux-h2: do not map Host to :authority on output
8882 - MEDIUM: h2: use the normalized URI encoding for absolute form requests
8883 - MINOR: stats: mention in the help message support for "json" and "typed"
8884 - MINOR: stats: get rid of the ST_CONVDONE flag
8885 - MINOR: stats: replace the ST_* uri_auth flags with STAT_*
8886 - MINOR: stats: always merge the uri_auth flags into the appctx flags
8887 - MINOR: stats: set the appctx flags when initializing the applet only
8888 - MINOR: stats: get rid of the STAT_SHOWADMIN flag
8889 - MINOR: stats: make stats_dump_fields_json() directly take flags
8890 - MINOR: stats: uniformize the calling convention of the dump functions
8891 - MINOR: stats: support the "desc" output format modifier for info and stat
8892 - MINOR: stats: prepare to add a description with each stat/info field
8893 - MINOR: stats: make "show stat" and "show info"
8894 - MINOR: stats: fill all the descriptions for "show info" and "show stat"
8895 - BUG/MEDIUM: applet: always check a fast running applet's activity before killing
8896 - BUILD: stats: fix missing '=' sign in array declaration
8897 - MINOR: lists: add new macro LIST_SPLICE_END_DETACHED
8898 - MINOR: list: add new macro MT_LIST_BEHEAD
8899 - MEDIUM: task: Split the tasklet list into two lists.
8900 - MINOR: h2: Document traps to be avoided on multithread.
8901 - MINOR: lists: Try to use local variables instead of macro arguments.
8902 - MINOR: lists: Fix alignement of \ when relevant.
8903 - MINOR: mux-h2: also support emitting CONTINUATION on trailers
8904 - MINOR: ssl: crt-list do ckchn_lookup
8905 - REORG: ssl: rename ckch_node to ckch_store
8906 - REORG: ssl: move structures to ssl_sock.h
8907 - MINOR: ssl: initialize the sni_keytypes_map as EB_ROOT
8908 - MINOR: ssl: initialize explicitly the sni_ctx trees
8909 - BUG/MINOR: ssl: abort on sni allocation failure
8910 - BUG/MINOR: ssl: free the sni_keytype nodes
8911 - BUG/MINOR: ssl: abort on sni_keytypes allocation failure
8912 - MEDIUM: ssl: introduce the ckch instance structure
8913 - MEDIUM: ssl: split ssl_sock_add_cert_sni()
8914 - MINOR: ssl: ssl_sock_load_ckchn() can properly fail
8915 - MINOR: ssl: ssl_sock_load_multi_ckchs() can properly fail
8916 - MEDIUM: ssl: ssl_sock_load_ckchs() alloc a ckch_inst
8917 - MINOR: ssl: ssl_sock_load_crt_file_into_ckch() is filling from a BIO
8918 - MEDIUM: ssl/cli: 'set ssl cert' updates a certificate from the CLI
8919 - MINOR: ssl: load the sctl in/from the ckch
8920 - MINOR: ssl: load the ocsp in/from the ckch
8921 - BUG/MEDIUM: ssl: NULL dereference in ssl_sock_load_cert_sni()
8922 - BUG/MINOR: ssl: fix build without SSL
8923 - BUG/MINOR: ssl: fix build without multi-cert bundles
8924 - BUILD: ssl: wrong #ifdef for SSL engines code
8925 - BUG/MINOR: ssl: fix OCSP build with BoringSSL
8926 - BUG/MEDIUM: htx: Catch chunk_memcat() failures when HTX data are formatted to h1
8927 - BUG/MINOR: chunk: Fix tests on the chunk size in functions copying data
8928 - BUG/MINOR: mux-h1: Mark the output buffer as full when the xfer is interrupted
8929 - MINOR: mux-h1: Xfer as much payload data as possible during output processing
8930 - CLEANUP: h1-htx: Move htx-to-h1 formatting functions from htx.c to h1_htx.c
8931 - BUG/MINOR: mux-h1: Capture ignored parsing errors
8932 - MINOR: h1: Reject requests with different occurrences of the header host
8933 - MINOR: h1: Reject requests if the authority does not match the header host
8934 - REGTESTS: Send valid URIs in peers reg-tests and fix HA config to avoid warnings
8935 - REGTESTS: Adapt proxy_protocol_random_fail.vtc to match normalized URI too
8936 - BUG/MINOR: WURFL: fix send_log() function arguments
8937 - BUG/MINOR: ssl: fix error messages for OCSP loading
8938 - BUG/MINOR: ssl: can't load ocsp files
8939 - MINOR: version: make the version strings variables, not constants
8940 - BUG/MINOR: http-htx: Properly set htx flags on error files to support keep-alive
8941 - MINOR: htx: Add a flag on HTX to known when a response was generated by HAProxy
8942 - MINOR: mux-h1: Force close mode for proxy responses with an unfinished request
8943 - BUILD: travis-ci: limit build to branches "master" and "next"
8944 - BUILD/MEDIUM: threads: rename thread_info struct to ha_thread_info
8945 - BUILD/SMALL: threads: enable threads on osx
8946 - BUILD/MEDIUM: threads: enable cpu_affinity on osx
8947 - MINOR: istbuf: add b_fromist() to make a buffer from an ist
8948 - BUG/MINOR: cache: also cache absolute URIs
8949 - BUG/MINOR: mworker/ssl: close openssl FDs unconditionally
8950 - BUG/MINOR: tcp: Don't alter counters returned by tcp info fetchers
8951 - BUG/MEDIUM: lists: Handle 1-element-lists in MT_LIST_BEHEAD().
8952 - BUG/MEDIUM: mux_pt: Make sure we don't have a conn_stream before freeing.
8953 - BUG/MEDIUM: tasklet: properly compute the sleeping threads mask in tasklet_wakeup()
8954 - BUG/MAJOR: idle conns: schedule the cleanup task on the correct threads
8955 - BUG/MEDIUM: task: make tasklets either local or shared but not both at once
8956 - Revert e8826ded5fea3593d89da2be5c2d81c522070995.
8957 - BUG/MEDIUM: mux_pt: Don't destroy the connection if we have a stream attached.
8958 - BUG/MEDIUM: mux_pt: Only call the wake emthod if nobody subscribed to receive.
8959 - REGTEST: mcli/mcli_show_info: launch a 'show info' on the master CLI
8960 - CLEANUP: ssl: make ssl_sock_load_cert*() return real error codes
8961 - CLEANUP: ssl: make ssl_sock_load_ckchs() return a set of ERR_*
8962 - CLEANUP: ssl: make cli_parse_set_cert handle errcode and warnings.
8963 - CLEANUP: ssl: make ckch_inst_new_load_(multi_)store handle errcode/warn
8964 - CLEANUP: ssl: make ssl_sock_put_ckch_into_ctx handle errcode/warn
8965 - CLEANUP: ssl: make ssl_sock_load_dh_params handle errcode/warn
8966 - CLEANUP: bind: handle warning label on bind keywords parsing.
8967 - BUG/MEDIUM: ssl: 'tune.ssl.default-dh-param' value ignored with openssl > 1.1.1
8968 - BUG/MINOR: mworker/cli: reload fail with inherited FD
8969 - BUG/MINOR: ssl: Fix fd leak on error path when a TLS ticket keys file is parsed
8970 - BUG/MINOR: stick-table: Never exceed (MAX_SESS_STKCTR-1) when fetching a stkctr
8971 - BUG/MINOR: cache: alloc shctx after check config
8972 - BUG/MINOR: sample: Make the `field` converter compatible with `-m found`
8973 - BUG/MINOR: server: check return value of fopen() in apply_server_state()
8974 - REGTESTS: make seamless-reload depend on 1.9 and above
8975 - REGTESTS: server/cli_set_fqdn requires version 1.8 minimum
8976 - BUG/MINOR: dns: allow srv record weight set to 0
8977 - BUG/MINOR: ssl: fix memcpy overlap without consequences.
8978 - BUG/MINOR: stick-table: fix an incorrect 32 to 64 bit key conversion
8979 - BUG/MEDIUM: pattern: make the pattern LRU cache thread-local and lockless
8980 - BUG/MINOR: mux-h2: do not emit logs on backend connections
8981 - CLEANUP: ssl: remove old TODO commentary
8982 - CLEANUP: ssl: fix SNI/CKCH lock labels
8983 - MINOR: ssl: OCSP functions can load from file or buffer
8984 - MINOR: ssl: load sctl from buf OR from a file
8985 - MINOR: ssl: load issuer from file or from buffer
8986 - MINOR: ssl: split ssl_sock_load_crt_file_into_ckch()
8987 - BUG/MINOR: ssl/cli: fix looking up for a bundle
8988 - MINOR: ssl/cli: update ocsp/issuer/sctl file from the CLI
8989 - MINOR: ssl: update ssl_sock_free_cert_key_and_chain_contents
8990 - MINOR: ssl: copy a ckch from src to dst
8991 - MINOR: ssl: new functions duplicate and free a ckch_store
8992 - MINOR: ssl/cli: assignate a new ckch_store
8993 - MEDIUM: cli/ssl: handle the creation of SSL_CTX in an IO handler
8994 - BUG/MINOR: ssl/cli: fix build of SCTL and OCSP
8995 - BUG/MINOR: ssl/cli: out of bounds when built without ocsp/sctl
8996 - BUG/MINOR: ssl: fix build with openssl < 1.1.0
8997 - BUG/MINOR: ssl: fix build of X509_chain_up_ref() w/ libreSSL
8998 - MINOR: tcp: avoid confusion in time parsing init
8999 - MINOR: debug: add a new "debug dev stream" command
9000 - MINOR: cli/debug: validate addresses using may_access() in "debug dev stream"
9001 - REORG: move CLI access level definitions to cli.h
9002 - MINOR: cli: add an expert mode to hide dangerous commands
9003 - MINOR: debug: make most debug CLI commands accessible in expert mode
9004 - MINOR: stats/debug: maintain a counter of debug commands issued
9005 - BUG/MEDIUM: debug: address a possible null pointer dereference in "debug dev stream"
9006
Willy Tarreaucb8f03f2019-10-01 18:13:09 +020090072019/10/01 : 2.1-dev2
9008 - DOC: management: document reuse and connect counters in the CSV format
9009 - DOC: management: document cache_hits and cache_lookups in the CSV format
9010 - BUG/MINOR: dns: remove irrelevant dependency on a client connection
9011 - MINOR: applet: make appctx use their own pool
9012 - BUG/MEDIUM: checks: Don't attempt to receive data if we already subscribed.
9013 - BUG/MEDIUM: http/htx: unbreak option http_proxy
9014 - BUG/MINOR: backend: do not try to install a mux when the connection failed
9015 - MINOR: mux-h2: Don't adjust anymore the amount of data sent in h2_snd_buf()
9016 - BUG/MINOR: http_fetch: Fix http_auth/http_auth_group when called from TCP rules
9017 - BUG/MINOR: http_htx: Initialize HTX error messages for TCP proxies
9018 - BUG/MINOR: cache/htx: Make maxage calculation HTX aware
9019 - BUG/MINOR: hlua: Make the function txn:done() HTX aware
9020 - MINOR: proto_htx: Directly call htx_check_response_for_cacheability()
9021 - MINOR: proto_htx: Rely on the HTX function to apply a redirect rules
9022 - MINOR: proto_htx: Add the function htx_return_srv_error()
9023 - MINOR: backend/htx: Don't rewind output data to set the sni on a srv connection
9024 - MINOR: proto_htx: Don't stop forwarding when there is a post-connect processing
9025 - DOC: htx: Update comments in HTX files
9026 - CLEANUP: htx: Remove the unsued function htx_add_blk_type_size()
9027 - MINOR: htx: Deduce the number of used blocks from tail and head values
9028 - MINOR: htx: Use an array of char to store HTX blocks
9029 - MINOR: htx: Slightly update htx_dump() to report better messages
9030 - DOC: htx: Add internal documentation about the HTX
9031 - MAJOR: http: Deprecate and ignore the option "http-use-htx"
9032 - MEDIUM: mux-h2: Remove support of the legacy HTTP mode
9033 - CLEANUP: h2: Remove functions converting h2 requests to raw HTTP/1.1 ones
9034 - MINOR: connection: Remove the multiplexer protocol PROTO_MODE_HTX
9035 - MINOR: stream: Rely on HTX analyzers instead of legacy HTTP ones
9036 - MEDIUM: http_fetch: Remove code relying on HTTP legacy mode
9037 - MINOR: config: Remove tests on the option 'http-use-htx'
9038 - MINOR: stream: Remove tests on the option 'http-use-htx' in stream_new()
9039 - MINOR: proxy: Remove tests on the option 'http-use-htx' during H1 upgrade
9040 - MINOR: hlua: Remove tests on the option 'http-use-htx' to reject TCP applets
9041 - MINOR: cache: Remove tests on the option 'http-use-htx'
9042 - MINOR: contrib/prometheus-exporter: Remove tests on the option 'http-use-htx'
9043 - CLEANUP: proxy: Remove the flag PR_O2_USE_HTX
9044 - MINOR: proxy: Don't adjust connection mode of HTTP proxies anymore
9045 - MEDIUM: backend: Remove code relying on the HTTP legacy mode
9046 - MEDIUM: hlua: Remove code relying on the legacy HTTP mode
9047 - MINOR: http_act: Remove code relying on the legacy HTTP mode
9048 - MEDIUM: cache: Remove code relying on the legacy HTTP mode
9049 - MEDIUM: compression: Remove code relying on the legacy HTTP mode
9050 - MINOR: flt_trace: Remove code relying on the legacy HTTP mode
9051 - MINOR: stats: Remove code relying on the legacy HTTP mode
9052 - MAJOR: filters: Remove code relying on the legacy HTTP mode
9053 - MINOR: stream: Remove code relying on the legacy HTTP mode
9054 - MAJOR: http: Remove the HTTP legacy code
9055 - MINOR: hlua: Remove useless test on TX_CON_WANT_* flags
9056 - MINOR: proto_http: Remove unused http txn flags
9057 - MINOR: proto_http: Remove the unused flag HTTP_MSGF_WAIT_CONN
9058 - CLEANUP: proto_http: Group remaining flags of the HTTP transaction
9059 - CLEANUP: channel: Remove the unused flag CF_WAKE_CONNECT
9060 - CLEANUP: proto_http: Remove unecessary includes and comments
9061 - CLEANUP: proto_http: Move remaining code from proto_http.c to proto_htx.c
9062 - REORG: proto_htx: Move HTX analyzers & co to http_ana.{c,h} files
9063 - BUG/MINOR: debug: Remove flags CO_FL_SOCK_WR_ENA/CO_FL_SOCK_RD_ENA
9064 - MINOR: proxy: Remove support of the option 'http-tunnel'
9065 - DOC: config: Update as a result of the legacy HTTP removal
9066 - MEDIUM: config: Remove parsing of req* and rsp* directives
9067 - MINOR: proxy: Remove the unused list of block rules
9068 - MINOR: proxy/http_ana: Remove unused req_exp/rsp_exp and req_add/rsp_add lists
9069 - DOC: config: Remove unsupported req* and rsp* keywords
9070 - MINOR: global: Preset tune.max_http_hdr to its default value
9071 - MINOR: http: Don't store raw HTTP errors in chunks anymore
9072 - BUG/MINOR: session: Emit an HTTP error if accept fails only for H1 connection
9073 - BUG/MINOR: session: Send a default HTTP error if accept fails for a H1 socket
9074 - CLEANUP: mux-h2: Remove unused flags H2_SF_CHNK_*
9075 - BUG/MINOR: checks: do not exit tcp-checks from the middle of the loop
9076 - MINOR: config: Warn only if the option http-use-htx is used with "no" prefix
9077 - BUG/MEDIUM: mux-h1: Trim excess server data at the end of a transaction
9078 - MINOR: connection: add conn_get_src() and conn_get_dst()
9079 - MINOR: frontend: switch to conn_get_{src,dst}() for logging and debugging
9080 - MINOR: backend: switch to conn_get_{src,dst}() for port and address mapping
9081 - MINOR: ssl: switch to conn_get_dst() to retrieve the destination address
9082 - MINOR: tcp: replace various calls to conn_get_{from,to}_addr with conn_get_{src,dst}
9083 - MINOR: stream-int: use conn_get_{src,dst} in conn_si_send_proxy()
9084 - MINOR: stream/cli: use conn_get_{src,dst} in "show sess" and "show peers" output
9085 - MINOR: log: use conn_get_{dst,src}() to retrieve the cli/frt/bck/srv/ addresses
9086 - MINOR: http/htx: use conn_get_dst() to retrieve the destination address
9087 - MINOR: lua: use conn_get_{src,dst} to retrieve connection addresses
9088 - MINOR: http: check the source address via conn_get_src() in sample fetch functions
9089 - CLEANUP: connection: remove the now unused conn_get_{from,to}_addr()
9090 - MINOR: connection: add new src and dst fields
9091 - MINOR: connection: use conn->{src,dst} instead of &conn->addr.{from,to}
9092 - MINOR: ssl-sock: use conn->dst instead of &conn->addr.to
9093 - MINOR: lua: switch to conn->dst for a connection's target address
9094 - MINOR: peers: use conn->dst for the peer's target address
9095 - MINOR: htx: switch from conn->addr.{from,to} to conn->{src,dst}
9096 - MINOR: stream: switch from conn->addr.{from,to} to conn->{src,dst}
9097 - MINOR: proxy: switch to conn->src in error snapshots
9098 - MINOR: session: use conn->src instead of conn->addr.from
9099 - MINOR: tcp: replace conn->addr.{from,to} with conn->{src,dst}
9100 - MINOR: unix: use conn->dst for the target address in ->connect()
9101 - MINOR: sockpair: use conn->dst for the target address in ->connect()
9102 - MINOR: log: use conn->{src,dst} instead of conn->addr.{from,to}
9103 - MINOR: checks: replace conn->addr.to with conn->dst
9104 - MINOR: frontend: switch from conn->addr.{from,to} to conn->{src,dst}
9105 - MINOR: http: convert conn->addr.from to conn->src in sample fetches
9106 - MEDIUM: backend: turn all conn->addr.{from,to} to conn->{src,dst}
9107 - MINOR: connection: create a new pool for struct sockaddr_storage
9108 - MEDIUM: connection: make sure all address producers allocate their address
9109 - MAJOR: connection: remove the addr field
9110 - MINOR: connection: don't use clear_addr() anymore, just release the address
9111 - MINOR: stream: add a new target_addr entry in the stream structure
9112 - MAJOR: stream: store the target address into s->target_addr
9113 - MINOR: peers: now remove the remote connection setup code
9114 - MEDIUM: lua: do not allocate the remote connection anymore
9115 - MEDIUM: backend: always release any existing prior connection in connect_server()
9116 - MEDIUM: backend: remove impossible cases from connect_server()
9117 - BUG/MINOR: mux-h1: Close server connection if input data remains in h1_detach()
9118 - BUG/MEDIUM: tcp-checks: do not dereference inexisting conn_stream
9119 - BUG/MINOR: http_ana: Be sure to have an allocated buffer to generate an error
9120 - BUG/MINOR: http_htx: Support empty errorfiles
9121 - BUG/CRITICAL: http_ana: Fix parsing of malformed cookies which start by a delimiter
9122 - BUG/MEDIUM: protocols: add a global lock for the init/deinit stuff
9123 - BUG/MINOR: proxy: always lock stop_proxy()
9124 - MEDIUM: mux-h1: Add the support of headers adjustment for bogus HTTP/1 apps
9125 - BUILD: threads: add the definition of PROTO_LOCK
9126 - BUG/MEDIUM: lb-chash: Fix the realloc() when the number of nodes is increased
9127 - BUG/MEDIUM: streams: Don't switch the SI to SI_ST_DIS if we have data to send.
9128 - BUG/MINOR: log: make sure writev() is not interrupted on a file output
9129 - DOC: improve the wording in CONTRIBUTING about how to document a bug fix
9130 - MEDIUM: h1: Don't try to subscribe if we managed to read data.
9131 - MEDIUM: h1: Don't wake the H1 tasklet if we got the whole request.
9132 - REGTESTS: checks: exclude freebsd target for tcp-check_multiple_ports.vtc
9133 - BUG/MINOR: hlua/htx: Reset channels analyzers when txn:done() is called
9134 - BUG/MEDIUM: hlua: Check the calling direction in lua functions of the HTTP class
9135 - MINOR: hlua: Don't set request analyzers on response channel for lua actions
9136 - MINOR: hlua: Add a flag on the lua txn to know in which context it can be used
9137 - BUG/MINOR: hlua: Only execute functions of HTTP class if the txn is HTTP ready
9138 - BUG/MINOR: htx: Fix free space addresses calculation during a block expansion
9139 - MINOR: ssl: merge ssl_sock_load_cert_file() and ssl_sock_load_cert_chain_file()
9140 - MEDIUM: ssl: use cert_key_and_chain struct in ssl_sock_load_cert_file()
9141 - MEDIUM: ssl: split the loading of the certificates
9142 - MEDIUM: ssl: lookup and store in a ckch_node tree
9143 - MEDIUM: ssl: load DH param in struct cert_key_and_chain
9144 - BUG/MAJOR: queue/threads: avoid an AB/BA locking issue in process_srv_queue()
9145 - MINOR: ssl: use STACK_OF for chain certs
9146 - MINOR: ssl: add extra chain compatibility
9147 - MINOR: ssl: check private key consistency in loading
9148 - MINOR: ssl: do not look at DHparam with OPENSSL_NO_DH
9149 - CLEANUP: ssl: ssl_sock_load_crt_file_into_ckch
9150 - MINOR: ssl: clean ret variable in ssl_sock_load_ckchn
9151 - MAJOR: fd: Get rid of the fd cache.
9152 - MEDIUM: pollers: Remember the state for read and write for each threads.
9153 - MEDIUM: mux-h2: don't try to read more than needed
9154 - BUG/BUILD: ssl: fix build with openssl < 1.0.2
9155 - BUG/MEDIUM: ssl: does not try to free a DH in a ckch
9156 - BUG/MINOR: debug: fix a small race in the thread dumping code
9157 - MINOR: wdt: also consider that waiting in the thread dumper is normal
9158 - REGTESTS: checks: make 4be_1srv_health_checks more reliable
9159 - BUILD: ssl: BoringSSL add EVP_PKEY_base_id
9160 - BUG/MEDIUM: ssl: don't free the ckch in multi-cert bundle
9161 - BUG/MINOR: ssl: fix ressource leaks on error
9162 - BUG/MEDIUM: lb-chash: Ensure the tree integrity when server weight is increased
9163 - BUG/MAJOR: http/sample: use a static buffer for raw -> htx conversion
9164 - BUG/MINOR: stream-int: make sure to always release empty buffers after sending
9165 - BUG/MEDIUM: ssl: open the right path for multi-cert bundle
9166 - BUG/MINOR: stream-int: also update analysers timeouts on activity
9167 - BUG/MEDIUM: mux-h2: unbreak receipt of large DATA frames
9168 - BUG/MEDIUM: mux-h2: split the stream's and connection's window sizes
9169 - BUG/MEDIUM: proxy: Make sure to destroy the stream on upgrade from TCP to H2
9170 - DOC: Add 'Question.md' issue template, discouraging asking questions
9171 - BUG/MEDIUM: fd: Always reset the polled_mask bits in fd_dodelete().
9172 - BUG/MEDIUM: pollers: Clear the poll_send bits as well.
9173 - BUILD: travis-ci: enable daily Coverity scan
9174 - BUG/MINOR: mux-h2: don't refrain from sending an RST_STREAM after another one
9175 - BUG/MINOR: mux-h2: use CANCEL, not STREAM_CLOSED in h2c_frt_handle_data()
9176 - BUG/MINOR: mux-h2: do not send REFUSED_STREAM on aborted uploads
9177 - BUG/MEDIUM: mux-h2: do not recheck a frame type after a state transition
9178 - BUG/MINOR: mux-h2: always send stream window update before connection's
9179 - BUG/MINOR: mux-h2: always reset rcvd_s when switching to a new frame
9180 - BUG/MEDIUM: checks: make sure to close nicely when we're the last to speak
9181 - BUG/MEDIUM: stick-table: Wrong stick-table backends parsing.
9182 - CLEANUP: mux-h2: move the demuxed frame check code in its own function
9183 - MINOR: cache: add method to cache hash
9184 - MINOR: cache: allow caching of OPTIONS request
9185 - BUG/MINOR: ssl: fix 0-RTT for BoringSSL
9186 - MINOR: ssl: ssl_fc_has_early should work for BoringSSL
9187 - BUG/MINOR: pools: don't mark the thread harmless if already isolated
9188 - BUG/MINOR: buffers/threads: always clear a buffer's head before releasing it
9189 - CLEANUP: buffer: replace b_drop() with b_free()
9190 - CLEANUP: task: move the cpu_time field to the task-only part
9191 - MINOR: cli: add two new states to print messages on the CLI
9192 - MINOR: cli: add cli_msg(), cli_err(), cli_dynmsg(), cli_dynerr()
9193 - CLEANUP: cli: replace all occurrences of manual handling of return messages
9194 - BUG/MEDIUM: proxy: Don't forget the SF_HTX flag when upgrading TCP=>H1+HTX.
9195 - BUG/MEDIUM: proxy: Don't use cs_destroy() when freeing the conn_stream.
9196 - BUG/MINOR: lua: fix setting netfilter mark
9197 - BUG/MINOR: Fix prometheus '# TYPE' and '# HELP' headers
9198 - BUG/MEDIUM: lua: Fix test on the direction to set the channel exp timeout
9199 - BUG/MINOR: stats: Wait the body before processing POST requests
9200 - MINOR: fd: make sure to mark the thread as not stuck in fd_update_events()
9201 - BUG/MEDIUM: mux_pt: Don't call unsubscribe if we did not subscribe.
9202 - BUILD: travis-ci: trigger non-mainstream configurations only on daily builds.
9203 - MINOR: debug: indicate the applet name when the task is task_run_applet()
9204 - MINOR: tools: add append_prefixed_str()
9205 - MINOR: lua: export applet and task handlers
9206 - MEDIUM: debug: make the thread dump code show Lua backtraces
9207 - BUG/MEDIUM: h1: Always try to receive more in h1_rcv_buf().
9208 - MINOR: list: add LIST_SPLICE() to merge one list into another
9209 - MINOR: tools: add a DEFNULL() macro to use NULL for empty args
9210 - REORG: trace: rename trace.c to calltrace.c and mention it's not thread-safe
9211 - MINOR: sink: create definitions a minimal code for event sinks
9212 - MINOR: sink: add a support for file descriptors
9213 - MINOR: trace: start to create a new trace subsystem
9214 - MINOR: trace: add allocation of buffer-sized trace buffers
9215 - MINOR: trace/cli: register the "trace" CLI keyword to list the sources
9216 - MINOR: trace/cli: parse the "level" argument to configure the trace verbosity
9217 - MINOR: trace/cli: add "show trace" to report trace state and statistics
9218 - MINOR: trace: implement a very basic trace() function
9219 - MINOR: trace: add the file name and line number in the prefix
9220 - MINOR: trace: make trace() now also take a level in argument
9221 - MINOR: trace: implement a call to a decode function
9222 - MINOR: trace: add per-level macros to produce traces
9223 - MINOR: trace: add a definition of typed arguments to trace()
9224 - MINOR: trace: make sure to always stop the locking when stopping or pausing
9225 - MINOR: trace: add the possibility to lock on some arguments
9226 - MINOR: trace: parse the "lock" argument to trace
9227 - MINOR: trace: retrieve useful pointers and enforce lock-on
9228 - DOC: management: document the "trace" and "show trace" commands
9229 - BUILD: trace: make the lockon_ptr const to silence a warning without threads
9230 - BUG/MEDIUM: mux-h1: do not truncate trailing 0CRLF on buffer boundary
9231 - BUG/MEDIUM: mux-h1: do not report errors on transfers ending on buffer full
9232 - DOC: fixed typo in management.txt
9233 - BUG/MINOR: mworker: disable SIGPROF on re-exec
9234 - BUG/MEDIUM: listener/threads: fix an AB/BA locking issue in delete_listener()
9235 - BUG/MEDIUM: url32 does not take the path part into account in the returned hash.
9236 - MINOR: backend: Add srv_queue converter
9237 - MINOR: sink: set the fd-type sinks to non-blocking
9238 - MINOR: tools: add a function varint_bytes() to report the size of a varint
9239 - MINOR: buffer: add functions to read/write varints from/to buffers
9240 - MINOR: fd: add fd_write_frag_line() to send a fragmented line to an fd
9241 - MINOR: sink: now call the generic fd write function
9242 - MINOR: ring: add a new mechanism for retrieving/storing ring data in buffers
9243 - MINOR: ring: add a ring_write() function
9244 - MINOR: ring: add a generic CLI io_handler to dump a ring buffer
9245 - MINOR: sink: add support for ring buffers
9246 - MINOR: sink: implement "show events" to show supported sinks and dump the rings
9247 - MINOR: sink: now report the number of dropped events on output
9248 - MINOR: trace: support a default callback for the source
9249 - MINOR: trace: extend the source location to 13 chars
9250 - MINOR: trace: show thread number and source name in the trace
9251 - MINOR: trace: change the TRACE() calling convention to put the args and cb last
9252 - MINOR: connection: add the fc_pp_authority fetch -- authority TLV, from PROXYv2
9253 - MINOR: tools: add a generic struct "name_desc" for name-description pairs
9254 - MINOR: trace: replace struct trace_lockon_args with struct name_desc
9255 - MINOR: trace: change the "payload" level to "data" and move it
9256 - MINOR: trace: prepend the function name for developer level traces
9257 - MINOR: trace: also report the trace level in the output
9258 - MINOR: trace: change the detail_level to per-source verbosity
9259 - MINOR: mux-h2/trace: register a new trace source with its events
9260 - MINOR: mux-h2/trace: add the default decoding callback
9261 - MEDIUM: mux-h2/trace: add lots of traces all over the code
9262 - MINOR: mux-h2: add functions to convert an h2c/h2s state to a string
9263 - MINOR: mux-h2/trace: add a new verbosity level "clean"
9264 - MINOR: mux-h2/trace: only decode the start-line at verbosity other than "minimal"
9265 - MINOR: mux-h2/trace: always report the h2c/h2s state and flags
9266 - MINOR: mux-h2/trace: report h2s->id before h2c->dsi for the stream ID
9267 - CLEANUP: mux-h2/trace: reformat the "received" messages for better alignment
9268 - CLEANUP: mux-h2/trace: lower-case event names
9269 - MINOR: trace: extend default event names to 12 chars
9270 - BUG/MINOR: ring: fix the way watchers are counted
9271 - MINOR: cli: extend the CLI context with a list and two offsets
9272 - MINOR: mux-h2/trace: report the connection pointer and state before FRAME_H
9273 - MEDIUM: ring: implement a wait mode for watchers
9274 - BUG/MEDIUM: mux-h2/trace: do not dereference h2c->conn after failed idle
9275 - BUG/MEDIUM: mux-h2/trace: fix missing braces added with traces
9276 - BUG/MINOR: ring: b_peek_varint() returns a uint64_t, not a size_t
9277 - CLEANUP: fd: remove leftovers of the fdcache
9278 - MINOR: fd: add a new "initialized" bit in the fdtab struct
9279 - MINOR: fd/log/sink: make the non-blocking initialization depend on the initialized bit
9280 - MEDIUM: log: use the new generic fd_write_frag_line() function
9281 - MINOR: log: add a target type instead of hacking the address family
9282 - MEDIUM: log: add support for logging to a ring buffer
9283 - MINOR: send-proxy-v2: sends authority TLV according to TLV received
9284 - MINOR: build: add linux-glibc-legacy build TARGET
9285 - BUG/MEDIUM: peers: local peer socket not bound.
9286 - BUILD: connection: silence gcc warning with extra parentheses
9287 - BUG/MINOR: http-ana: Reset response flags when 1xx messages are handled
9288 - BUG/MINOR: h1: Properly reset h1m when parsing is restarted
9289 - BUG/MINOR: mux-h1: Fix size evaluation of HTX messages after headers parsing
9290 - BUG/MINOR: mux-h1: Don't stop anymore input processing when the max is reached
9291 - BUG/MINOR: mux-h1: Be sure to update the count before adding EOM after trailers
9292 - BUG/MEDIUM: cache: Properly copy headers splitted on several shctx blocks
9293 - BUG/MEDIUM: cache: Don't cache objects if the size of headers is too big
9294 - BUG/MINOR: mux-h1: Fix a possible null pointer dereference in h1_subscribe()
9295 - MEDIUM: fd: remove the FD_EV_POLLED status bit
9296 - MEDIUM: fd: simplify the fd_*_{recv,send} functions using BTS/BTR
9297 - MINOR: fd: make updt_fd_polling() a normal function
9298 - CONTRIB: debug: add new program "poll" to test poll() events
9299 - BUG/MINOR: checks: stop polling for write when we have nothing left to send
9300 - BUG/MINOR: checks: start sending the request right after connect()
9301 - BUG/MINOR: checks: make __event_chk_srv_r() report success before closing
9302 - BUG/MINOR: checks: do not uselessly poll for reads before the connection is up
9303 - BUG/MINOR: mux-h1: Fix a UAF in cfg_h1_headers_case_adjust_postparser()
9304 - BUILD: CI: add basic CentOS 6 cirrus build
9305 - MINOR: contrib/prometheus-exporter: Report DRAIN/MAINT/NOLB status for servers
9306 - BUG/MINOR: lb/leastconn: ignore the server weights for empty servers
9307 - BUG/MAJOR: ssl: ssl_sock was not fully initialized.
9308 - MEDIUM: fd: mark the FD as ready when it's inserted
9309 - MINOR: fd: add two new calls fd_cond_{recv,send}()
9310 - MEDIUM: connection: enable reading only once the connection is confirmed
9311 - MINOR: fd: add two flags ERR and SHUT to describe FD states
9312 - MEDIUM: fd: do not use the FD_POLL_* flags in the pollers anymore
9313 - BUG/MEDIUM: connection: don't keep more idle connections than ever needed
9314 - MINOR: stats: report the number of idle connections for each server
9315 - BUILD: CI: skip reg-tests/connection/proxy_protocol_random_fail.vtc on CentOS 6
9316 - BUILD/MINOR: auth: enabling for osx
9317 - BUG/MINOR: listener: Fix a possible null pointer dereference
9318 - BUG/MINOR: ssl: always check for ssl connection before getting its XPRT context
9319 - MINOR: stats: Add JSON export from the stats page
9320 - BUG/MINOR: filters: Properly set the HTTP status code on analysis error
9321 - MINOR: sample: Add UUID-fetch
9322 - CLEANUP: mux-h2: Remove unused flag H2_SF_DATA_CHNK
9323 - BUG/MINOR: acl: Fix memory leaks when an ACL expression is parsed
9324 - BUG/MINOR: backend: Fix a possible null pointer dereference
9325 - BUG/MINOR: Missing stat_field_names (since f21d17bb)
9326 - BUG/MEDIUM: stick-table: Properly handle "show table" with a data type argument
9327 - BUILD: CI: temporarily disable ASAN
9328 - MINOR: htx: Add a flag on HTX message to report processing errors
9329 - MINOR: mux-h1: Report a processing error during output processing
9330 - MINOR: http-ana: Handle HTX errors first during message analysis
9331 - MINOR: http-ana: Remove err_state field from http_msg
9332 - MINOR: config: Support per-proxy and per-server deinit functions callbacks
9333 - MINOR: config: Support per-proxy and per-server post-check functions callbacks
9334 - MINOR: http_fetch: Add sample fetches to get auth method/user/pass
9335 - MINOR: istbuf: Add the function b_isteqi()
9336 - MINOR: log: Provide a function to emit a log for an application
9337 - MINOR: http: Add function to parse value of the header Status
9338 - MEDIUM: mux-h1/h1-htx: move HTX convertion of H1 messages in dedicated file
9339 - MINOR: h1-htx: Use the same function to copy message payload in all cases
9340 - MINOR: muxes/htx: Ignore pseudo header during message formatting
9341 - MINOR: fcgi: Add code related to FCGI protocol
9342 - MEDIUM: fcgi-app: Add FCGI application and filter
9343 - MEDIUM: mux-fcgi: Add the FCGI multiplexer
9344 - MINOR: doc: Add documentation about the FastCGI support
9345 - BUG/MINOR: build: Fix compilation of mux_fcgi.c when compiled without SSL
9346 - BUILD: CI: install golang-1.13 when building BoringSSL
9347 - BUG/MINOR: mux-h2: Be sure to have a connection to unsubcribe
9348 - BUG/MINOR: mux-fcgi: Be sure to have a connection to unsubcribe
9349 - CLEANUP: fcgi-app: Remove useless test on fcgi_conf pointer
9350 - BUG/MINOR: mux-fcgi: Don't compare the filter name in its parsing callback
9351 - BUG/MAJOR: mux-h2: Handle HEADERS frames received after a RST_STREAM frame
9352 - BUG/MEDIUM: check/threads: make external checks run exclusively on thread 1
9353 - MEDIUM: list: Separate "locked" list from regular list.
9354 - MINOR: mt_lists: Add new macroes.
9355 - MEDIUM: servers: Use LIST_DEL_INIT() instead of LIST_DEL().
9356 - MINOR: mt_lists: Do nothing in MT_LIST_ADD/MT_LIST_ADDQ if already in list.
9357 - MINOR: mt_lists: Give MT_LIST_ADD, MT_LIST_ADDQ and MT_LIST_DEL a return value.
9358 - MEDIUM: tasklets: Make the tasklet list a struct mt_list.
9359 - TESTS: Add a stress-test for mt_lists.
9360 - BUILD: travis-ci: add PCRE2, SLZ build
9361 - BUG/MINOR: build: fix event ports (Solaris)
9362 - BUG/MEDIUM: namespace: fix fd leak in master-worker mode
9363 - OPTIM: listeners: use tasklets for the multi-queue rings
9364 - BUILD: makefile: work around yet another GCC fantasy (-Wstring-plus-int)
9365 - BUG/MINOR: stream-int: Process connection/CS errors first in si_cs_send()
9366 - BUG/MEDIUM: stream-int: Process connection/CS errors during synchronous sends
9367 - BUG/MEDIUM: checks: make sure the connection is ready before trying to recv
9368 - CLEANUP: task: remove impossible test
9369 - CLEANUP: task: cache the task_per_thread pointer
9370 - MINOR: task: split the tasklet vs task code in process_runnable_tasks()
9371 - MINOR: task: introduce a thread-local "sched" variable for local scheduler stuff
9372 - CLEANUP: mux-fcgi: Remove the unused function fcgi_strm_id()
9373 - BUG/MINOR: mux-fcgi: Use a literal string as format in app_log()
9374 - BUG/MEDIUM: tasklets: Make sure we're waking the target thread if it sleeps.
9375 - MINOR: h2/trace: indicate 'F' or 'B' to locate the side of an h2c in traces
9376 - MINOR: h2/trace: report the frame type when known
9377 - BUG/MINOR: mux-h2: do not wake up blocked streams before the mux is ready
9378 - BUG/MEDIUM: namespace: close open namespaces during soft shutdown
9379 - MINOR: time: add timeofday_as_iso_us() to return instant time as ISO
9380 - MINOR: sink: finally implement support for SINK_FMT_{TIMED,ISO}
9381 - MINOR: sink: change ring buffer "buf0"'s format to "timed"
9382 - BUG/MEDIUM: mux-h2: don't reject valid frames on closed streams
9383 - BUG/MINOR: mux-fcgi: silence a gcc warning about null dereference
9384 - BUG/MINOR: mux-h2: Fix missing braces because of traces in h2_detach()
9385 - BUG/MINOR: mux-h2: Use the dummy error when decoding headers for a closed stream
9386 - BUG/MAJOR: mux_h2: Don't consume more payload than received for skipped frames
9387 - BUG/MINOR: mux-h1: Do h2 upgrade only on the first request
9388 - BUG/MEDIUM: spoe: Use a different engine-id per process
9389 - MINOR: spoe: Improve generation of the engine-id
9390 - MINOR: spoe: Support the async mode with several threads
9391 - MINOR: http: Add server name header from HTTP multiplexers
9392 - CLEANUP: http-ana: Remove the unused function http_send_name_header()
9393 - MINOR: stats: Add the support of float fields in stats
9394 - BUG/MINOR: contrib/prometheus-exporter: Return the time averages in seconds
9395 - DOC: Fix documentation about the cli command to get resolver stats
9396 - BUG/MEDIUM: fcgi: fix missing list tail in sample fetch registration
9397 - BUG/MINOR: stats: Add a missing break in a switch statement
9398 - BUG/MINOR: lua: Properly initialize the buffer's fields for string samples in hlua_lua2(smp|arg)
9399 - CLEANUP: lua: Get rid of obsolete (size_t *) cast in hlua_lua2(smp|arg)
9400 - BUG/MEDIUM: lua: Store stick tables into the sample's `t` field
9401 - CLEANUP: proxy: Remove `proxy_tbl_by_name`
9402 - BUILD: ssl: fix a warning when built with openssl < 1.0.2
9403 - DOC: replace utf-8 quotes by ascii ones
9404 - BUG/MEDIUM: fd: HUP is an error only when write is active
9405 - BUG/MINOR: action: do-resolve does not yield on requests with body
9406 - Revert "MINOR: cache: allow caching of OPTIONS request"
9407
Willy Tarreaudb514072019-07-16 19:15:28 +020094082019/07/16 : 2.1-dev1
9409 - BUG/MEDIUM: h2/htx: Update data length of the HTX when the cookie list is built
9410 - DOC: this is a development branch again.
9411 - MEDIUM: Make 'block' directive fatal
9412 - MEDIUM: Make 'redispatch' directive fatal
9413 - MEDIUM: Make '(cli|con|srv)timeout' directive fatal
9414 - MEDIUM: Remove 'option independant-streams'
9415 - MINOR: sample: Add sha2([<bits>]) converter
9416 - MEDIUM: server: server-state global file stored in a tree
9417 - BUG/MINOR: lua/htx: Make txn.req_req_* and txn.res_rep_* HTX aware
9418 - BUG/MINOR: mux-h1: Add the header connection in lower case in outgoing messages
9419 - BUG/MEDIUM: compression: Set Vary: Accept-Encoding for compressed responses
9420 - MINOR: htx: Add the function htx_change_blk_value_len()
9421 - BUG/MEDIUM: htx: Fully update HTX message when the block value is changed
9422 - BUG/MEDIUM: mux-h2: Reset padlen when several frames are demux
9423 - BUG/MEDIUM: mux-h2: Remove the padding length when a DATA frame size is checked
9424 - BUG/MEDIUM: lb_fwlc: Don't test the server's lb_tree from outside the lock
9425 - BUG/MAJOR: sample: Wrong stick-table name parsing in "if/unless" ACL condition.
9426 - BUILD: mworker: silence two printf format warnings around getpid()
9427 - BUILD: makefile: use :space: instead of digits to count commits
9428 - BUILD: makefile: adjust the sed expression of "make help" for solaris
9429 - BUILD: makefile: do not rely on shell substitutions to determine git version
9430 - BUG/MINOR: mworker-prog: Fix segmentation fault during cfgparse
9431 - BUG/MINOR: spoe: Fix memory leak if failing to allocate memory
9432 - BUG/MEDIUM: mworker: don't call the thread and fdtab deinit
9433 - BUG/MEDIUM: stream_interface: Don't add SI_FL_ERR the state is < SI_ST_CON.
9434 - BUG/MEDIUM: connections: Always add the xprt handshake if needed.
9435 - BUG/MEDIUM: ssl: Don't do anything in ssl_subscribe if we have no ctx.
9436 - BUG/MEDIUM: mworker/cli: command pipelining doesn't work anymore
9437 - BUG/MINOR: htx: Save hdrs_bytes when the HTX start-line is replaced
9438 - BUG/MAJOR: mux-h1: Don't crush trash chunk area when outgoing message is formatted
9439 - BUG/MINOR: memory: Set objects size for pools in the per-thread cache
9440 - BUG/MINOR: log: Detect missing sampling ranges in config
9441 - BUG/MEDIUM: proto_htx: Don't add EOM on 1xx informational messages
9442 - BUG/MEDIUM: mux-h1: Use buf_room_for_htx_data() to detect too large messages
9443 - BUG/MINOR: mux-h1: Make format errors during output formatting fatal
9444 - BUG/MEDIUM: ssl: Don't attempt to set alpn if we're not using SSL.
9445 - BUG/MEDIUM: mux-h1: Always release H1C if a shutdown for writes was reported
9446 - BUG/MINOR: mworker/cli: don't output a \n before the response
9447 - BUG/MEDIUM: checks: unblock signals in external checks
9448 - BUG/MINOR: mux-h1: Skip trailers for non-chunked outgoing messages
9449 - BUG/MINOR: mux-h1: Don't return the empty chunk on HEAD responses
9450 - BUG/MEDIUM: connections: Always call shutdown, with no linger.
9451 - BUG/MEDIUM: checks: Make sure the tasklet won't run if the connection is closed.
9452 - BUG/MINOR: contrib/prometheus-exporter: Don't use channel_htx_recv_max()
9453 - BUG/MINOR: hlua: Don't use channel_htx_recv_max()
9454 - BUG/MEDIUM: channel/htx: Use the total HTX size in channel_htx_recv_limit()
9455 - BUG/MINOR: hlua/htx: Respect the reserve when HTX data are sent
9456 - BUG/MINOR: contrib/prometheus-exporter: Respect the reserve when data are sent
9457 - BUG/MEDIUM: connections: Make sure we're unsubscribe before upgrading the mux.
9458 - BUG/MEDIUM: servers: Authorize tfo in default-server.
9459 - BUG/MEDIUM: sessions: Don't keep an extra idle connection in sessions.
9460 - MINOR: server: Add "no-tfo" option.
9461 - BUG/MINOR: contrib/prometheus-exporter: Don't try to add empty data blocks
9462 - MINOR: action: Add the return code ACT_RET_DONE for actions
9463 - BUG/MEDIUM: http/applet: Finish request processing when a service is registered
9464 - BUG/MEDIUM: lb_fas: Don't test the server's lb_tree from outside the lock
9465 - BUG/MEDIUM: mux-h1: Handle TUNNEL state when outgoing messages are formatted
9466 - BUG/MINOR: mux-h1: Don't process input or ouput if an error occurred
9467 - MINOR: stream-int: Factorize processing done after sending data in si_cs_send()
9468 - BUG/MEDIUM: stream-int: Don't rely on CF_WRITE_PARTIAL to unblock opposite si
9469 - DOC: contrib: spoa_server Add some hints for building spoa_server
9470 - DOC: Fix typo in intro.txt
9471 - BUG/MEDIUM: servers: Don't forget to set srv_cs to NULL if we can't reuse it.
9472 - BUG/MINOR: ssl: revert empty handshake detection in OpenSSL <= 1.0.2
9473 - MINOR: pools: release the pool's lock during the malloc/free calls
9474 - MINOR: pools: always pre-initialize allocated memory outside of the lock
9475 - MINOR: pools: make the thread harmless during the mmap/munmap syscalls
9476 - BUG/MEDIUM: fd/threads: fix excessive CPU usage on multi-thread accept
9477 - BUG/MINOR: server: Be really able to keep "pool-max-conn" idle connections
9478 - BUG/MEDIUM: checks: Don't attempt to read if we destroyed the connection.
9479 - BUG/MEDIUM: da: cast the chunk to string.
9480 - DOC: Fix typos and grammer in configuration.txt
9481 - CLEANUP: proto_tcp: Remove useless header inclusions.
9482 - BUG/MEDIUM: servers: Fix a race condition with idle connections.
9483 - MINOR: task: introduce work lists
9484 - BUG/MAJOR: listener: fix thread safety in resume_listener()
9485 - BUG/MEDIUM: mux-h1: Don't release h1 connection if there is still data to send
9486 - BUG/MINOR: mux-h1: Correctly report Ti timer when HTX and keepalives are used
9487 - BUG/MEDIUM: streams: Don't give up if we couldn't send the request.
9488 - BUG/MEDIUM: streams: Don't redispatch with L7 retries if redispatch isn't set.
9489 - BUG/MINOR: mux-pt: do not pretend there's more data after a read0
9490 - BUG/MEDIUM: tcp-check: unbreak multiple connect rules again
9491 - MEDIUM: mworker-prog: Add user/group options to program section
9492 - REGTESTS: checks: tcp-check connect to multiple ports
9493 - BUG/MEDIUM: threads: cpu-map designating a single thread/process are ignored
9494
Willy Tarreau9dc6b972019-06-16 21:49:47 +020094952019/06/16 : 2.1-dev0
9496 - exact copy of 2.0.0
9497
Willy Tarreauba236302019-06-16 20:00:26 +020094982019/06/16 : 2.0.0
9499 - MINOR: fd: Don't use atomic operations when it's not needed.
9500 - DOC: mworker-prog: documentation for the program section
9501 - MINOR: http: add a new "http-request replace-uri" action
9502 - BUG/MINOR: 51d/htx: The _51d_fetch method, and the methods it calls are now HTX aware.
9503 - MINOR: 51d: Added dummy libraries for the 51Degrees module for testing.
9504 - MINOR: mworker: change formatting in uptime field of "show proc"
9505 - MINOR: mworker: add the HAProxy version in "show proc"
9506 - MINOR: doc: Remove -Ds option in man page
9507 - MINOR: doc: add master-worker in the man page
9508 - MINOR: doc: mention HAPROXY_LOCALPEER in the man
9509 - BUILD: Silence gcc warning about unused return value
9510 - CLEANUP: 51d: move the 51d dummy lib to contrib/51d/src to match the real lib
9511 - BUILD: travis-ci: add 51Degree device detection, update openssl to 1.1.1c
9512 - MINOR: doc: update the manpage and usage message about -S
9513 - BUILD/MINOR: 51d: Updated build registration output to indicate thatif the library is a dummy one or not.
9514 - BUG/MEDIUM: h1: Don't wait for handshake if we had an error.
9515 - BUG/MEDIUM: h1: Wait for the connection if the handshake didn't complete.
9516 - BUG/MINOR: task: prevent schedulable tasks from starving under high I/O activity
9517 - BUG/MINOR: fl_trace/htx: Be sure to always forward trailers and EOM
9518 - BUG/MINOR: channel/htx: Call channel_htx_full() from channel_full()
9519 - BUG/MINOR: http: Use the global value to limit the number of parsed headers
9520 - BUG/MINOR: htx: Detect when tail_addr meet end_addr to maximize free rooms
9521 - BUG/MEDIUM: htx: Don't change position of the first block during HTX analysis
9522 - CLEANUP: channel: Remove channel_htx_fwd_payload() and channel_htx_fwd_all()
9523 - BUG/MEDIUM: proto_htx: Introduce the state ENDING during forwarding
9524 - MINOR: htx: Add 3 flags on the start-line to deal with the request schemes
9525 - MINOR: h2: Set flags about the request's scheme on the start-line
9526 - MINOR: mux-h1: Set flags about the request's scheme on the start-line
9527 - MINOR: mux-h2: Forward clients scheme to servers checking start-line flags
9528 - MEDIUM: server: server-state only rely on server name
9529 - CLEANUP: connection: rename the wait_event.task field to .tasklet
9530 - CLEANUP: tasks: rename task_remove_from_tasklet_list() to tasklet_remove_*
9531 - BUG/MEDIUM: connections: Don't call shutdown() if we want to disable linger.
9532 - DOC: add some environment variables in section 2.3
9533 - BUILD: makefile: clarify the "help" output and list options
9534 - BUG/MINOR: mux-h1: Wake busy mux for I/O when message is fully sent
9535 - BUG: tasks: fix bug introduced by latest scheduler cleanup
9536 - BUG/MEDIUM: mux-h2: fix early close with option abortonclose
9537 - BUG/MEDIUM: connections: Don't use ALPN to pick mux when in mode TCP.
9538 - BUG/MEDIUM: connections: Don't try to send early data if we have no mux.
9539 - BUG/MEDIUM: mux-h2: properly account for the appended data in HTX
9540 - BUILD: makefile: further clarify the "help" output and list targets
9541 - BUILD: makefile: rename "linux2628" to "linux-glibc" and remove older targets
9542 - BUILD: travis-ci: switch to linux-glibc instead of linux2628
9543 - DOC: update few references to the linux* targets and change them to linux-glibc
9544 - BUILD: makefile: detect and reject recently removed linux targets
9545 - BUILD: makefile: enable linux namespaces by default on linux
9546 - BUILD: makefile: enable TFO on linux platforms
9547 - BUILD: makefile: enable getaddrinfo on the linux-glibc target
9548 - DOC: small updates to the CONTRIBUTING file
9549 - BUG/MEDIUM: ssl: Make sure we initiate the handshake after using early data.
9550 - CLEANUP: removed obsolete examples an move a few to better places
9551 - DOC: Fix typos in CONTRIBUTING
9552 - DOC: update the outdated ROADMAP file
9553 - DOC: create a BRANCHES file to explain the life cycle
9554 - DOC: mention in INSTALL haproxy 2.0 is a long-term supported stable version
9555 - BUILD: travis-ci: TFO and GETADDRINFO are now enabled by default
9556 - BUILD: makefile: make the obsolete target detection compatible with make-3.80
9557 - BUILD: tools: work around an internal compiler bug in gcc-3.4
9558 - BUILD: pattern: work around an internal compiler bug in gcc-3.4
9559 - BUILD: makefile: enable USE_RT on Solaris
9560 - BUILD: makefile: do not use echo -n
9561 - DOC: mention a few common build errors in the INSTALL file
9562
Willy Tarreauca3551f2019-06-11 19:28:00 +020095632019/06/11 : 2.0-dev7
9564 - BUG/MEDIUM: mux-h2: make sure the connection timeout is always set
9565 - MINOR: tools: add new bitmap manipulation functions
9566 - MINOR: logs: use the new bitmap functions instead of fd_sets for encoding maps
9567 - MINOR: chunks: Make sure trash_size is only set once.
9568 - Revert "MINOR: chunks: Make sure trash_size is only set once."
9569 - MINOR: threads: serialize threads initialization
9570 - MINOR peers: data structure simplifications for server names dictionary cache.
9571 - DOC: peers: Update for dictionary cache entries for peers protocol.
9572 - MINOR: dict: Store the length of the dictionary entries.
9573 - MINOR: peers: A bit of optimization when encoding cached server names.
9574 - MINOR: peers: Optimization for dictionary cache lookup.
9575 - MEDIUM: tools: improve time format error detection
9576 - BUG/MEDIUM: H1: When upgrading, make sure we don't free the buffer too early.
9577 - BUG/MEDIUM: stream_interface: Make sure we call si_cs_process() if CS_FL_EOI.
9578 - MINOR: threads: avoid clearing harmless twice in thread_release()
9579 - MEDIUM: threads: add thread_sync_release() to synchronize steps
9580 - BUG/MEDIUM: init/threads: prevent initialized threads from starting before others
9581 - OPTIM/MINOR: init/threads: only call protocol_enable_all() on first thread
9582 - BUG/MINOR: dict: race condition fix when inserting dictionary entries.
9583 - MEDIUM: init/threads: don't use spinlocks during the init phase
9584 - BUG/MINOR: cache/htx: Fix the counting of data already sent by the cache applet
9585 - BUG/MEDIUM: compression/htx: Fix the adding of the last data block
9586 - MINOR: flt_trace: Don't scrash the original offset during the random forwarding
9587 - MAJOR: htx: Rework how free rooms are tracked in an HTX message
9588 - MINOR: htx: Add the function htx_move_blk_before()
9589 - Revert "BUG/MEDIUM: H1: When upgrading, make sure we don't free the buffer too early."
9590 - BUG/MINOR: http-rules: mention "deny_status" for "deny" in the error message
9591 - MINOR: http: turn default error files to HTTP/1.1
9592 - BUG/MEDIUM: h1: Don't try to subscribe if we had a connection error.
9593 - BUG/MEDIUM: h1: Don't consider we're connected if the handshake isn't done.
9594 - MINOR: contrib/spoa_server: Upgrade SPOP to 2.0
9595 - BUG/MEDIUM: contrib/spoa_server: Set FIN flag on agent frames
9596 - MINOR: contrib/spoa_server: Add random IP score
9597 - DOC/MINOR: contrib/spoa_server: Fix typo in README
9598
Willy Tarreaub57f1092019-06-07 06:12:59 +020095992019/06/07 : 2.0-dev6
9600 - BUG/MEDIUM: connection: fix multiple handshake polling issues
9601 - MINOR: connection: also stop receiving after a SOCKS4 response
9602 - MINOR: mux-h1: don't try to recv() before the connection is ready
9603 - BUG/MEDIUM: mux-h1: only check input data for the current stream, not next one
9604 - MEDIUM: mux-h1: don't use CS_FL_REOS anymore
9605 - CLEANUP: connection: remove the now unused CS_FL_REOS flag
9606 - CONTRIB: debug: add 4 missing connection/conn_stream flags
9607 - MEDIUM: stream: make a full process_stream() loop when completing I/O on exit
9608 - MINOR: server: increase the default pool-purge-delay to 5 seconds
9609 - BUILD: tools: do not use the weak attribute for trace() on obsolete linkers
9610 - BUG/MEDIUM: vars: make sure the scope is always valid when accessing vars
9611 - BUG/MEDIUM: vars: make the tcp/http unset-var() action support conditions
9612 - BUILD: task: fix a build warning when threads are disabled
9613 - CLEANUP: peers: Remove tabs characters.
9614 - CLEANUP: peers: Replace hard-coded values by macros.
9615 - BUG/MINOR: peers: Wrong stick-table update message building.
9616 - MINOR: dict: Add dictionary new data structure.
9617 - MINOR: peers: Add a LRU cache implementation for dictionaries.
9618 - MINOR: stick-table: Add "server_name" new data type.
9619 - MINOR: cfgparse: Space allocation for "server_name" stick-table data type.
9620 - MINOR: proxy: Add a "server by name" tree to proxy.
9621 - MINOR: server: Add a dictionary for server names.
9622 - MINOR: stream: Stickiness server lookup by name.
9623 - MINOR: peers: Make peers protocol support new "server_name" data type.
9624 - MINOR: stick-table: Make the CLI stick-table handler support dictionary entry data type.
9625 - REGTEST: Add a basic server by name stickiness reg test.
9626 - MINOR: peers: Add dictionary cache information to "show peers" CLI command.
9627 - MINOR: peers: Replace hard-coded for peer protocol 64-bits value encoding by macros.
9628 - MINOR: peers: Replace hard-coded values for peer protocol messaging by macros.
9629 - CLEANUP: ssl: remove unneeded defined(OPENSSL_IS_BORINGSSL)
9630 - BUILD: travis-ci improvements
9631 - MINOR: SSL: add client/server random sample fetches
9632 - BUG/MINOR: channel/htx: Don't alter channel during forward for empty HTX message
9633 - BUG/MINOR: contrib/prometheus-exporter: Add HTX data block in one time
9634 - BUG/MINOR: mux-h1: errflag must be set on H1S and not H1M during output processing
9635 - MEDIUM: mux-h1: refactor output processing
9636 - MINOR: mux-h1: Add the flag HAVE_O_CONN on h1s
9637 - MINOR: mux-h1: Add h1_eval_htx_hdrs_size() to estimate size of the HTX headers
9638 - MINOR: mux-h1: Don't count the EOM in the estimated size of headers
9639 - MEDIUM: cache/htx: Always store info about HTX blocks in the cache
9640 - MEDIUM: htx: Add the parsing of trailers of chunked messages
9641 - MINOR: htx: Don't use end-of-data blocks anymore
9642 - BUG/MINOR: mux-h1: Don't send more data than expected
9643 - BUG/MINOR: flt_trace/htx: Only apply the random forwarding on the message body.
9644 - BUG/MINOR: peers: Wrong "server_name" decoding.
9645 - BUG/MEDIUM: servers: Don't attempt to destroy idle connections if disabled.
9646 - MEDIUM: checks: Make sure we unsubscribe before calling cs_destroy().
9647 - MEDIUM: connections: Wake the upper layer even if sending/receiving is disabled.
9648 - MEDIUM: ssl: Handle subscribe by itself.
9649 - MINOR: ssl: Make ssl_sock_handshake() static.
9650 - MINOR: connections: Add a new xprt method, remove_xprt.
9651 - MINOR: connections: Add a new xprt method, add_xprt().
9652 - MEDIUM: connections: Introduce a handshake pseudo-XPRT.
9653 - MEDIUM: connections: Remove CONN_FL_SOCK*
9654 - BUG/MEDIUM: ssl: Don't forget to initialize ctx->send_recv and ctx->recv_wait.
9655 - BUG/MINOR: peers: Wrong server name parsing.
9656 - MINOR: server: really increase the pool-purge-delay default to 5 seconds
9657 - BUG/MINOR: stream: don't emit a send-name-header in conn error or disconnect states
9658 - MINOR: stream-int: use bit fields to match multiple stream-int states at once
9659 - MEDIUM: stream-int: remove dangerous interval checks for stream-int states
9660 - MEDIUM: stream-int: introduce a new state SI_ST_RDY
9661 - MAJOR: stream-int: switch from SI_ST_CON to SI_ST_RDY on I/O
9662 - MEDIUM: stream-int: make idle-conns switch to ST_RDY
9663 - MEDIUM: stream: re-arrange the connection setup status reporting
9664 - MINOR: stream-int: split si_update() into si_update_rx() and si_update_tx()
9665 - MINOR: stream-int: make si_sync_send() from the send code of si_update_both()
9666 - MEDIUM: stream: rearrange the events to remove the loop
9667 - MEDIUM: stream: only loop on flags relevant to the analysers
9668 - MEDIUM: stream: don't abusively loop back on changes on CF_SHUT*_NOW
9669 - BUILD: stream-int: avoid a build warning in dev mode in si_state_bit()
9670 - BUILD: peers: fix a build warning about an incorrect intiialization
9671 - BUG/MINOR: time: make sure only one thread sets global_now at boot
9672 - BUG/MEDIUM: tcp: Make sure we keep the polling consistent in tcp_probe_connect.
9673
Willy Tarreauabc874e2019-06-02 12:06:08 +020096742019/06/02 : 2.0-dev5
9675 - BUILD: watchdog: use si_value.sival_int, not si_int for the timer's value
9676 - BUILD: signals: FreeBSD has SI_LWP instead of SI_TKILL
9677 - BUILD: watchdog: condition it to USE_RT
9678 - MINOR: raw_sock: report global traffic statistics
9679 - MINOR: stats: report the global output bit rate in human readable form
9680 - BUG/MINOR: proto-htx: Try to keep connections alive on redirect
9681 - BUG/MEDIUM: spoe: Don't use the SPOE applet after releasing it
9682 - BUG/MINOR: lua: Set right direction and flags on new HTTP objects
9683 - BUG/MINOR: mux-h2: Count EOM in bytes sent when a HEADERS frame is formatted
9684 - BUG/MINOR: mux-h1: Report EOI instead EOS on parsing error or H2 upgrade
9685 - BUG/MEDIUM: proto-htx: Not forward too much data when 1xx reponses are handled
9686 - BUG/MINOR: htx: Remove a forgotten while loop in htx_defrag()
9687 - DOC: fix typos
9688 - BUG/MINOR: ssl_sock: Fix memory leak when disabling compression
9689 - OPTIM: freq-ctr: don't take the date lock for most updates
9690 - MEDIUM: mux-h2: avoid doing expensive buffer realigns when not absolutely needed
9691 - CLEANUP: debug: remove the TRACE() macro
9692 - MINOR: buffer: introduce b_make() to make a buffer from its parameters
9693 - MINOR: buffer: add a new buffer ring API to manipulate rings of buffers
9694 - MEDIUM: mux-h2: replace all occurrences of mbuf with a buffer ring
9695 - MEDIUM: mux-h2: make the conditions to send based on mbuf, not just its tail
9696 - MINOR: mux-h2: introduce h2_release_mbuf() to release all buffers in the mbuf ring
9697 - MEDIUM: mux-h2: make the send() function iterate over all mux buffers
9698 - CLEANUP: mux-h2: consistently use a local variable for the mbuf
9699 - MINOR: mux-h2: report the mbuf's head and tail in "show fd"
9700 - MAJOR: mux-h2: switch to next mux buffer on buffer full condition.
9701 - BUILD: connections: shut up gcc about impossible out-of-bounds warning
9702 - BUILD: ssl: fix latest LibreSSL reg-test error
9703 - MINOR: cli/activity: remove "fd_del" and "fd_skip" from show activity
9704 - MINOR: cli/activity: add 3 general purpose counters in development mode
9705 - BUG/MAJOR: lb/threads: make sure the avoided server is not full on second pass
9706 - BUG/MEDIUM: queue: fix the tree walk in pendconn_redistribute.
9707 - BUG/MEDIUM: threads: fix double-word CAS on non-optimized 32-bit platforms
9708 - MEDIUM: config: now alert when two servers have the same name
9709 - MINOR: htx: Remove the macro IS_HTX_SMP() and always use IS_HTX_STRM() instead
9710 - MINOR: htx: Move the macro IS_HTX_STRM() in proto/stream.h
9711 - MINOR: htx: Store the head position instead of the wrap one
9712 - MINOR: htx: Store start-line block's position instead of address of its payload
9713 - MINOR: htx: Add functions to get the first block of an HTX message
9714 - MINOR: mux-h2/htx: Get the start-line from the head when HEADERS frame is built
9715 - MINOR: htx: Replace the function http_find_stline() by http_get_stline()
9716 - CLEANUP: htx: Remove unused function htx_get_stline()
9717 - MINOR: http/htx: Use sl_pos directly to replace the start-line
9718 - MEDIUM: http/htx: Perform analysis relatively to the first block
9719 - MINOR: channel/htx: Call channel_htx_recv_max() from channel_recv_max()
9720 - MINOR: htx: Add function htx_get_max_blksz()
9721 - BUG/MINOR: htx: Change htx_xfer_blk() to also count metadata
9722 - MEDIUM: mux-h1: Use the count value received from the SI in h1_rcv_buf()
9723 - MINOR: mux-h2: Use the count value received from the SI in h2_rcv_buf()
9724 - MINOR: stream-int: Don't use the flag CO_RFL_KEEP_RSV anymore in si_cs_recv()
9725 - MINOR: connection: Remove the unused flag CO_RFL_KEEP_RSV
9726 - MINOR: mux-h2/htx: Support zero-copy when possible in h2_rcv_buf()
9727 - MINOR: htx: Add a field to set the memory used by headers in the HTX start-line
9728 - MINOR: h2/htx: Set hdrs_bytes on the SL when an HTX message is produced
9729 - MINOR: mux-h1: Set hdrs_bytes on the SL when an HTX message is produced
9730 - MINOR: htx: Be sure to xfer all headers in one time in htx_xfer_blks()
9731 - MEDIUM: htx: 1xx messages are now part of the final reponses
9732 - MINOR: channel/htx: Add function to forward headers of an HTX message
9733 - MINOR: filters/htx: Use channel_htx_fwd_headers() after headers filtering
9734 - MINOR: proto-htx: Use channel_htx_fwd_headers() to forward 1xx responses
9735 - MEDIUM: htx: Store the first block position instead of the start-line one
9736 - MINOR: stats/htx: don't use the first block position but the head one
9737 - MINOR: channel/htx: Add functions to forward a part or all HTX payload
9738 - MINOR: proto-htx: Use channel_htx_fwd_all() when unfiltered body are forwarded
9739 - MEDIUM: filters/htx: Filter body relatively to the first block
9740 - MINOR: htx: Optimize htx_drain() when all data are drained
9741 - MINOR: htx: don't rely on htx_find_blk() anymore in the function htx_truncate()
9742 - MINOR: htx: remove the unused function htx_find_blk()
9743 - MINOR: htx: Remove support of pseudo headers because it is unused
9744 - BUG/MEDIUM: http: fix "http-request reject" when not final
9745 - MINOR: ssl: Make sure the underlying xprt's init method doesn't fail.
9746 - MINOR: ssl: Don't forget to call the close method of the underlying xprt.
9747 - MINOR: htx: rename htx_append_blk_value() to htx_add_data_atonce()
9748 - MINOR: htx: make htx_add_data() return the transmitted byte count
9749 - MEDIUM: htx: make htx_add_data() never defragment the buffer
9750 - MINOR: activity: write totals on the "show activity" output
9751 - MINOR: activity: report totals and average separately
9752 - MEDIUM: poller: separate the wait time from the wake events
9753 - MINOR: activity: report the number of failed pool/buffer allocations
9754 - MEDIUM: buffers: relax the buffer lock a little bit
9755 - MINOR: task: turn the WQ lock to an RW_LOCK
9756 - MEDIUM: task: don't grab the WR lock just to check the WQ
9757 - BUG/MEDIUM: mux-h1: Don't skip the TCP splicing when there is no more data to read
9758 - MEDIUM: sessions: Introduce session flags.
9759 - BUG/MEDIUM: h2: Don't forget to set h2s->cs to NULL after having free'd cs.
9760 - BUG/MEDIUM: mux-h2: fix the conditions to end the h2_send() loop
9761 - BUG/MEDIUM: mux-h2: don't refrain from offering oneself a used buffer
9762 - BUG/MEDIUM: connection: Use the session to get the origin address if needed.
9763 - MEDIUM: tasks: Get rid of active_tasks_mask.
9764 - MEDIUM: connection: Upstream SOCKS4 proxy support
9765 - BUILD: contrib/prometheus: fix build breakage caused by move of idle_pct
9766 - BUG/MINOR: deinit/threads: make hard-stop-after perform a clean exit
9767
Willy Tarreau56740692019-05-22 20:48:33 +020097682019/05/22 : 2.0-dev4
9769 - BUILD: enable freebsd builds on cirrus-ci
9770 - BUG/MINOR: http_fetch: Rely on the smp direction for "cookie()" and "hdr()"
9771 - MEDIUM: Make 'option forceclose' actually warn
9772 - MEDIUM: Make 'resolution_pool_size' directive fatal
9773 - DOC: management: place "show activity" at the right place
9774 - MINOR: cli/activity: show the dumping thread ID starting at 1
9775 - MINOR: task: export global_task_mask
9776 - MINOR: cli/debug: add a thread dump function
9777 - BUG/MEDIUM: streams: Don't use CF_EOI to decide if the request is complete.
9778 - BUG/MEDIUM: streams: Try to L7 retry before aborting the connection.
9779 - BUG/MINOR: debug: make ha_task_dump() always check the task before dumping it
9780 - BUG/MINOR: debug: make ha_task_dump() actually dump the requested task
9781 - MINOR: debug: make ha_thread_dump() and ha_task_dump() take a buffer
9782 - BUG/MINOR: debug: don't check the call date on tasklets
9783 - MINOR: thread: implement ha_thread_relax()
9784 - MINOR: task: put barriers after each write to curr_task
9785 - MINOR: task: always reset curr_task when freeing a task or tasklet
9786 - MINOR: stream: detach the stream from its own task on stream_free()
9787 - MEDIUM: debug/threads: implement an advanced thread dump system
9788 - REGTEST: extend the check duration on tls_health_checks and mark it slow
9789 - DOC: fix "successful" typo
9790 - MINOR: init: setenv HAPROXY_CFGFILES
9791 - MINOR: threads/init: synchronize the threads startup
9792 - MEDIUM: init/mworker: make the pipe register function a regular initcall
9793 - CLEANUP: memory: make the fault injection code use the OTHER_LOCK label
9794 - CLEANUP: threads: remove the now unused START_LOCK label
9795 - MINOR: init/threads: make the global threads an array of structs
9796 - MINOR: threads: add each thread's clockid into the global thread_info
9797 - CLEANUP: stream: remove an obsolete debugging test
9798 - MINOR: tools: add dump_hex()
9799 - MINOR: debug: implement ha_panic()
9800 - MINOR: debug/cli: add some debugging commands for developers
9801 - MINOR: tools: provide a may_access() function and make dump_hex() use it
9802 - MINOR: debug: make ha_panic() report threads starting at 1
9803 - REORG: compat: move some integer limit definitions from standard.h to compat.h
9804 - REORG: threads: move the struct thread_info from global.h to hathreads.h
9805 - MINOR: compat: make sure to always define clockid_t
9806 - MINOR: threads: always place the clockid in the struct thread_info
9807 - MINOR: threads: add a thread-local thread_info pointer "ti"
9808 - MINOR: time: move the cpu, mono, and idle time to thread_info
9809 - MINOR: time: add a function to retrieve another thread's cputime
9810 - MINOR: debug: report each thread's cpu usage in "show thread"
9811 - BUILD: threads: only assign the clock_id when supported
9812 - BUILD: makefile: use USE_OBSOLETE_LINKER for solaris
9813 - BUILD: makefile: remove -fomit-frame-pointer optimisation (solaris)
9814 - MAJOR: polling: add event ports support (Solaris)
9815 - BUG/MEDIUM: streams: Don't switch from SI_ST_CON to SI_ST_DIS on read0.
9816 - CLEANUP: time: refine the test on _POSIX_TIMERS
9817 - MINOR: compat: define a new empty type empty_t for non-implemented fields
9818 - CLEANUP: time: switch clockid_t to empty_t when not available
9819 - BUG/MINOR: mworker: Fix memory leak of mworker_proc members
9820 - CLEANUP: objtype: make obj_type() and obj_type_name() take consts
9821 - MINOR: debug: switch to SIGURG for thread dumps
9822 - CLEANUP: threads: really move thread_info to hathreads.c
9823 - MINOR: threads: make threads_{harmless|want_rdv}_mask constant 0 without threads
9824 - CLEANUP: debug: always report harmless/want_rdv even without threads
9825 - MINOR: threads: implement ha_tkill() and ha_tkillall()
9826 - CLEANUP: debug: make use of ha_tkill() and remove ifdefs
9827 - MINOR: stream: introduce a stream_dump() function and use it in stream_dump_and_crash()
9828 - MINOR: debug: dump streams when an applet, iocb or stream is known
9829 - MINOR: threads: add a "stuck" flag to the thread_info struct
9830 - MINOR: threads: add a timer_t per thread in thread_info
9831 - MAJOR: watchdog: implement a thread lockup detection mechanism
9832 - MINOR: stream: remove the cpu time detection from process_stream()
9833 - MINOR: connection: report the mux names in "haproxy -vv"
9834 - CLEANUP: mux-h1: use "H1" and not "h1" as the mux's name
9835 - BUG/MEDIUM: WURFL: segfault in wurfl-get() with missing info.
9836 - MINOR: WURFL: call header_retireve_callback() in dummy library
9837 - MINOR: WURFL: fixed Engine load failed error when wurfl-information-list contains wurfl_root_id
9838 - MINOR: WURFL: shows log messages during module initialization
9839 - MINOR: WURFL: removes heading wurfl-information-separator from wurfl-get-all() and wurfl-get() results
9840 - MINOR: WURFL: wurfl_get() and wurfl_get_all() now return an empty string if device detection fails
9841 - MEDIUM: WURFL: HTX awareness.
9842 - MINOR: WURFL: module version bump to 2.0
9843 - MINOR: WURFL: do not emit warnings when not configured
9844 - CONTRIB: wurfl: address 3 build issues in the wurfl dummy library
9845 - BUG/MEDIUM: init/threads: provide per-thread alloc/free function callbacks
9846 - BUILD: travis: add sanitizers to travis-ci builds
9847 - BUILD: time: remove the test on _POSIX_C_SOURCE
9848 - CLEANUP: build: rename some build macros to use the USE_* ones
9849 - CLEANUP: raw_sock: remove support for very old linux splice bug workaround
9850 - BUG/MEDIUM: dns: make the port numbers unsigned
9851 - MEDIUM: config: deprecate the antique req* and rsp* commands
9852
Willy Tarreaua257a9b2019-05-15 16:51:48 +020098532019/05/15 : 2.0-dev3
9854 - BUG/MINOR: peers: Really close the sessions with no heartbeat.
9855 - CLEANUP: peers: remove useless annoying tabulations.
9856 - CLEANUP: peers: replace timeout constants by macros.
9857 - REGTEST: Enable again reg tests with HEAD HTTP method usage.
9858 - DOC: The option httplog is no longer valid in a backend.
9859 - DOC: peers: Peers protocol documentation update.
9860 - REGTEST: remove unexpected "nbthread" statement from Lua test cases
9861 - BUILD: Makefile: remove 11-years old workarounds for deprecated options
9862 - BUILD: remove 10-years old error message for obsolete option USE_TCPSPLICE
9863 - BUILD: Makefile: remove outdated support for dlmalloc
9864 - BUILD: Makefile: consider a variable's origin and not its value for the options list
9865 - BUILD: Makefile: also report disabled options in the BUILD_OPTIONS variable
9866 - BUILD: Makefile: shorten default settings declaration
9867 - BUILD: Makefile: clean up the target declarations
9868 - BUILD: report the whole feature set with their status in haproxy -vv
9869 - BUILD: pass all "USE_*" variables as -DUSE_* to the compiler
9870 - REGTEST: script: make the script use the new features list
9871 - REGTEST: script: remove platform-specific assigments of OPTIONS
9872 - BUG/MINOR: peers: Missing initializations after peer session shutdown.
9873 - BUG/MINOR: contrib/prometheus-exporter: Fix applet accordingly to recent changes
9874 - BUILD/MINOR: listener: Silent a few signedness warnings.
9875 - BUG/MINOR: mux-h1: Only skip invalid C-L headers on output
9876 - BUG/MEDIUM: mworker: don't free the wrong child when not found
9877 - BUG/MEDIUM: checks: Don't bother subscribing if we have a connection error.
9878 - BUG/MAJOR: checks: segfault during tcpcheck_main
9879 - BUILD: makefile: work around an old bug in GNU make-3.80
9880 - BUILD: makefile: work around another bug in make 3.80
9881 - BUILD: http: properly mark some struct as extern
9882 - BUILD: chunk: properly declare pool_head_trash as extern
9883 - BUILD: cache: avoid a build warning with some compilers/linkers
9884 - MINOR: tools: make memvprintf() never pass a NULL target to vsnprintf()
9885 - MINOR: tools: add an unsetenv() implementation
9886 - BUILD: re-implement an initcall variant without using executable sections
9887 - BUILD: use inttypes.h instead of stdint.h
9888 - BUILD: connection: fix naming of ip_v field
9889 - BUILD: makefile: fix build of IPv6 header on aix51
9890 - BUILD: makefile: add _LINUX_SOURCE_COMPAT to build on AIX-51
9891 - BUILD: define unsetenv on AIX 5.1
9892 - BUILD: Makefile: disable shared cache on AIX 5.1
9893 - MINOR: ssl: Add aes_gcm_dec converter
9894 - REORG: mworker: move serializing functions to mworker.c
9895 - REORG: mworker: move signals functions to mworker.c
9896 - REORG: mworker: move IPC functions to mworker.c
9897 - REORG: mworker: move signal handlers and related functions
9898 - REORG: mworker: move mworker_cleanlisteners to mworker.c
9899 - MINOR: mworker: calloc mworker_proc structures
9900 - MINOR: mworker: don't use children variable anymore
9901 - MINOR: cli: export cli_parse_default() definition in cli.h
9902 - REORG: mworker/cli: move CLI functions to mworker.c
9903 - MEDIUM: mworker-prog: implement program for master-worker
9904 - MINOR: mworker/cli: show programs in 'show proc'
9905 - BUG/MINOR: cli: correctly handle abns in 'show cli sockets'
9906 - MINOR: cli: start addresses by a prefix in 'show cli sockets'
9907 - MINOR: cli: export HAPROXY_CLI environment variable
9908 - BUG/MINOR: htx: Preserve empty HTX messages with an unprocessed parsing error
9909 - BUG/MINOR: proto_htx: Reset to_forward value when a message is set to DONE
9910 - REGTEST: http-capture/h00000: Relax a regex matching the log message
9911 - REGTEST: http-messaging/h00000: Fix the test when the HTX is enabled
9912 - REGTEST: http-rules/h00003: Use a different client for requests expecting a 301
9913 - REGTEST: log/b00000: Be sure the client always hits its timeout
9914 - REGTEST: lua/b00003: Relax the regex matching the log message
9915 - REGTEST: lua/b00003: Specify the HAProxy pid when the command ss is executed
9916 - BUG/MEDIUM: peers: fix a case where peer session is not cleanly reset on release.
9917 - BUG/MEDIUM: h2: Don't attempt to recv from h2_process_demux if we subscribed.
9918 - BUG/MEDIUM: htx: fix random premature abort of data transfers
9919 - BUG/MEDIUM: streams: Don't remove the SI_FL_ERR flag in si_update_both().
9920 - BUG/MEDIUM: streams: Store prev_state before calling si_update_both().
9921 - BUG/MEDIUM: stream: Don't clear the stream_interface flags in si_update_both.
9922 - MINOR: initcall: Don't forget to define the __start/stop_init_##stg symbols.
9923 - MINOR: threads: Implement thread_cpus_enabled() for FreeBSD.
9924 - BUG/MEDIUM: pattern: assign pattern IDs after checking the config validity
9925 - MINOR: skip get_gmtime where tm is unused
9926 - MINOR: ssl: Activate aes_gcm_dec converter for BoringSSL
9927 - BUG/MEDIUM: streams: Only re-run process_stream if we're in a connected state.
9928 - BUG/MEDIUM: stream_interface: Don't bother doing chk_rcv/snd if not connected.
9929 - BUG/MEDIUM: task/threads: address a fairness issue between local and global tasks
9930 - BUG/MINOR: tasks: make sure the first task to be queued keeps its nice value
9931 - BUG/MINOR: listener: renice the accept ring processing task
9932 - MINOR: cli/listener: report the number of accepts on "show activity"
9933 - MINOR: cli/activity: report the accept queue sizes in "show activity"
9934 - BUG/MEDIUM: spoe: Queue message only if no SPOE applet is attached to the stream
9935 - BUG/MEDIUM: spoe: Return an error if nothing is encoded for fragmented messages
9936 - BUG/MINOR: spoe: Be sure to set tv_request when each message fragment is encoded
9937 - BUG/MEDIUM: htx: Defrag if blocks position is changed and the payloads wrap
9938 - BUG/MEDIUM: htx: Don't crush blocks payload when append is done on a data block
9939 - MEDIUM: htx: Deprecate the option 'http-tunnel' and ignore it in HTX
9940 - MINOR: proto_htx: Don't adjust transaction mode anymore in HTX analyzers
9941 - BUG/MEDIUM: htx: Fix the process of HTTP CONNECT with h2 connections
9942 - MINOR: mux-h1: Simplify handling of 1xx responses
9943 - MINOR: stats/htx: Don't add "Connection: close" header anymore in stats responses
9944 - MEDIUM: h1: Add an option to sanitize connection headers during parsing
9945 - MEDIUM: mux-h1: Simplify the connection mode management by sanitizing headers
9946 - MINOR: mux-h1: Don't release the conn_stream anymore when h1s is destroyed
9947 - BUG/MINOR: mux-h1: Handle the flag CS_FL_KILL_CONN during a shutdown read/write
9948 - MINOR: mux-h2: Add a mux_ops dedicated to the HTX mode
9949 - MINOR: muxes: Add a flag to specify a multiplexer uses the HTX
9950 - MINOR: stream: Set a flag when the stream uses the HTX
9951 - MINOR: http: update the macro IS_HTX_STRM() to check the stream flag SF_HTX
9952 - MINOR: http_fetch/htx: Use stream flags instead of px mode in smp_prefetch_htx
9953 - MINOR: filters/htx: Use stream flags instead of px mode to instanciate a filter
9954 - MINOR: muxes: Rely on conn_is_back() during init to handle front/back conn
9955 - MEDIUM: muxes: Add an optional input buffer during mux initialization
9956 - MINOR: muxes: Pass the context of the mux to destroy() instead of the connection
9957 - MEDIUM: muxes: Be prepared to don't own connection during the release
9958 - MEDIUM: connection: Add conn_upgrade_mux_fe() to handle mux upgrades
9959 - MEDIUM: htx: Allow the option http-use-htx to be used on TCP proxies too
9960 - MAJOR: proxy/htx: Handle mux upgrades from TCP to HTTP in HTX mode
9961 - MAJOR: muxes/htx: Handle inplicit upgrades from h1 to h2
9962 - MAJOR: htx: Enable the HTX mode by default for all proxies
9963 - REGTEST: Use HTX by default and add '--no-htx' option to disable it
9964 - BUG/MEDIUM: muxes: Don't dereference mux context if null in release functions
9965 - CLEANUP: task: do not export rq_next anymore
9966 - MEDIUM: tasks: improve fairness between the local and global queues
9967 - MEDIUM: tasks: only base the nice offset on the run queue depth
9968 - MINOR: tasks: restore the lower latency scheduling when niced tasks are present
9969 - BUG/MEDIUM: map: Fix memory leak in the map converter
9970 - BUG/MINOR: ssl: Fix 48 byte TLS ticket key rotation
9971 - BUILD: task/thread: fix single-threaded build of task.c
9972 - BUILD: cli/threads: fix build in single-threaded mode
9973 - BUG/MEDIUM: muxes: Make sure we unsubcribed when destroying mux ctx.
9974 - BUG/MEDIUM: h2: Make sure we're not already in the send_list in h2_subscribe().
9975 - BUG/MEDIUM: h2: Revamp the way send subscriptions works.
9976 - MINOR: connections: Remove the SUB_CALL_UNSUBSCRIBE flag.
9977 - BUG/MEDIUM: Threads: Only use the gcc >= 4.7 builtins when using gcc >= 4.7.
9978 - BUILD: address a few cases of "static <type> inline foo()"
9979 - BUILD: do not specify "const" on functions returning structs or scalars
9980 - BUILD: htx: fix a used uninitialized warning on is_cookie2
9981 - MINOR: peers: Add a new command to the CLI for peers.
9982 - DOC: update for "show peers" CLI command.
9983 - BUG/MAJOR: lb/threads: fix insufficient locking on round-robin LB
9984 - MEDIUM: mworker: store the leaving state of a process
9985 - MEDIUM: mworker-prog: implements 'option start-on-reload'
9986 - CLEANUP: mworker: remove the type field in mworker_proc
9987 - MEDIUM: mworker/cli: export the HAPROXY_MASTER_CLI variable
9988 - MINOR: cli: don't add a semicolon at the end of HAPROXY_CLI
9989 - MINOR: mworker: export HAPROXY_MWORKER=1 when running in mworker mode
9990 - MINOR: init: add a "set-dumpable" global directive to enable core dumps
9991 - BUG/MINOR: listener/mq: correctly scan all bound threads under low load
9992 - BUG/MINOR: mworker: mworker_kill should apply on every children
9993 - BUG/MINOR: mworker: don't exit with an ambiguous value
9994 - BUG/MINOR: mworker: ensure that we still quits with SIGINT
9995 - REGTESTS: exclude tests that require ssl, pcre if no such feature is enabled
9996 - BUG/MINOR: mux-h1: Process input even if the input buffer is empty
9997 - BUG/MINOR: mux-h1: Don't switch the parser in busy mode if other side has done
9998 - BUG/MEDIUM: mux-h1: Notify the stream waiting for TCP splicing if ibuf is empty
9999 - BUG/MEDIUM: mux-h1: Enable TCP splicing to exchange data only
10000 - MINOR: mux-h1: Handle read0 during TCP splicing
10001 - BUG/MEDIUM: htx: Don't return the start-line if the HTX message is empty
10002 - BUG/MAJOR: http_fetch: Get the channel depending on the keyword used
10003 - BUG/MINOR: http_fetch/htx: Allow permissive sample prefetch for the HTX
10004 - BUG/MINOR: http_fetch/htx: Use HTX versions if the proxy enables the HTX mode
10005 - BUG/MEDIUM: tasks: Make sure we set TASK_QUEUED before adding a task to the rq.
10006 - BUG/MEDIUM: tasks: Make sure we modify global_tasks_mask with the rq_lock.
10007 - MINOR: tasks: Don't consider we can wake task with tasklet_wakeup().
10008 - MEDIUM: tasks: No longer use rq.node.leaf_p as a lock.
10009 - MINOR: tasks: Don't set the TASK_RUNNING flag when adding in the tasklet list.
10010 - BUG/MEDIUM: applets: Don't use task_in_rq().
10011 - BUG/MAJOR: task: make sure never to delete a queued task
10012 - MINOR: task/thread: factor out a wake-up condition
10013 - CLEANUP: task: remain consistent when using the task's handler
10014 - MEDIUM: tasks: Merge task_delete() and task_free() into task_destroy().
10015 - MEDIUM: tasks: Don't account a destroyed task as a runned task.
10016 - BUG/MINOR: contrib/prometheus-exporter: Fix a typo in the run-queue metric type
10017 - MINOR: contrib/prometheus-exporter: Remove usless rate metrics
10018 - MINOR: contrib/prometheus-exporter: Rename some metrics to be more usable
10019 - MINOR: contrib/prometheus-exporter: Follow best practices about metrics type
10020 - BUG/MINOR: mworker: disable busy polling in the master process
10021 - MEDIUM: tasks: Use __ha_barrier_store after modifying global_tasks_mask.
10022 - MEDIUM: ssl: Give ssl_sock its own context.
10023 - MEDIUM: connections: Move some fields from struct connection to ssl_sock_ctx.
10024 - MEDIUM: ssl: provide its own subscribe/unsubscribe function.
10025 - MEDIUM: connections: Provide a xprt_ctx for each xprt method.
10026 - MEDIUM: ssl: provide our own BIO.
10027 - BUILD/medium: ssl: Fix build with OpenSSL < 1.1.0
10028 - MINOR: peers: adds counters on show peers about tasks calls.
10029 - MEDIUM: enable travis-ci builds
10030 - MINOR: fd: Add a counter of used fds.
10031 - MEDIUM: connections: Add a way to control the number of idling connections.
10032 - BUG/MEDIUM: maps: only try to parse the default value when it's present
10033 - BUG/MINOR: acl: properly detect pattern type SMP_T_ADDR
10034 - REGTEST: Missing REQUIRE_VERSION declarations.
10035 - MINOR: proto_tcp: tcp-request content: enable set-dst and set-dst-var
10036 - BUG/MEDIUM: h1: Don't parse chunks CRLF if not enough data are available
10037 - BUG/MEDIUM: thread/http: Add missing locks in set-map and add-acl HTTP rules
10038 - BUG/MEDIUM: stream: Don't request a server connection if a shutw was scheduled
10039 - BUG/MINOR: 51d: Get the request channel to call CHECK_HTTP_MESSAGE_FIRST()
10040 - BUG/MINOR: da: Get the request channel to call CHECK_HTTP_MESSAGE_FIRST()
10041 - MINOR: gcc: Fix a silly gcc warning in connect_server()
10042 - MINOR: ssl/cli: async fd io-handlers printable on show fd
10043 - Revert "CLEANUP: wurfl: remove dead, broken and unmaintained code"
10044 - BUILD: add USE_WURFL to the list of known build options
10045 - MINOR: wurfl: indicate in haproxy -vv the wurfl version in use
10046 - BUILD: wurfl: build fix for 1.9/2.0 code base
10047 - CLEANUP: wurfl: removed deprecated methods
10048 - DOC: wurfl: added point of contact in MAINTAINERS file
10049 - MINOR: wurfl: enabled multithreading mode
10050 - MINOR: contrib: dummy wurfl library
10051 - MINOR: dns: dns_requester structures are now in a memory pool
10052 - MINOR: dns: move callback affection in dns_link_resolution()
10053 - MINOR: obj_type: new object type for struct stream
10054 - MINOR: action: new '(http-request|tcp-request content) do-resolve' action
10055 - MINOR: log: Extract some code to send syslog messages.
10056 - REGTEST: replace LEVEL option by a more human readable one.
10057 - REGTEST: rename the reg test files.
10058 - REGTEST: adapt some reg tests after renaming.
10059 - REGTEST: make the "run-regtests" script search for tests in reg-tests by default
10060 - BUG/MAJOR: stream: Missing DNS context initializations.
10061 - BUG/MEDIUM: stream: Fix the way early aborts on the client side are handled
10062 - BUG/MINOR: spoe: Don't systematically wakeup SPOE stream in the applet handler
10063 - BUG/MEDIUM: ssl: Return -1 on recv/send if we got EAGAIN.
10064 - BUG/MAJOR: lb/threads: fix AB/BA locking issue in round-robin LB
10065 - BUG/MAJOR: muxes: Use the HTX mode to find the best mux for HTTP proxies only
10066 - BUG/MINOR: htx: Exclude TCP proxies when the HTX mode is handled during startup
10067 - CLEANUP: task: report calls as unsigned in show sess
10068 - MINOR: tasks/activity: report the context switch and task wakeup rates
10069 - MINOR: stream: measure and report a stream's call rate in "show sess"
10070 - MINOR: applet: measure and report an appctx's call rate in "show sess"
10071 - BUILD: extend Travis CI config to support more platforms
10072 - REGTEST: exclude osx and generic targets for 40be_2srv_odd_health_checks
10073 - REGTEST: relax the IPv6 address format checks in converters_ipmask_concat_strcmp_field_word
10074 - REGTEST: exclude OSX and generic targets from abns_socket.vtc
10075 - BUILD: travis: remove the "allow_failures" entry
10076 - BUG/MINOR: activity: always initialize the profiling variable
10077 - MINOR: activity: make the profiling status per thread and not global
10078 - MINOR: activity: enable automatic profiling turn on/off
10079 - CLEANUP: standard: use proper const to addr_to_str() and port_to_str()
10080 - BUG/MINOR: proto_http: properly reset the stream's call rate on keep-alive
10081 - MINOR: connection: make the debugging helper functions safer
10082 - MINOR: stream/debug: make a stream dump and crash function
10083 - MEDIUM: appctx/debug: force a crash if an appctx spins over itself forever
10084 - MEDIUM: stream/debug: force a crash if a stream spins over itself forever
10085 - MEDIUM: streams: measure processing time and abort when detecting bugs
10086 - BUILD/MEDIUM: contrib: Dummy DeviceAtlas API.
10087 - MEDIUM: da: HTX mode support.
10088 - BUG/MEDIUM: mux-h2: properly deal with too large headers frames
10089 - BUG/MINOR: http: Call stream_inc_be_http_req_ctr() only one time per request
10090 - BUG/MEDIUM: spoe: arg len encoded in previous frag frame but len changed
10091 - MINOR: spoe: Use the sample context to pass frag_ctx info during encoding
10092 - DOC: contrib/modsecurity: Typos and fix the reject example
10093 - BUG/MEDIUM: contrib/modsecurity: If host header is NULL, don't try to strdup it
10094 - MINOR: log: Add "sample" new keyword to "log" lines.
10095 - MINOR: log: Enable the log sampling and load-balancing feature.
10096 - DOC: log: Document the sampling and load-balancing logging feature.
10097 - REGTEST: Add a new reg test for log load-balancing feature.
10098 - BUG/MAJOR: map/acl: real fix segfault during show map/acl on CLI
10099 - REGTEST: Make this reg test be Linux specific.
10100 - CLEANUP: task: move the task_per_thread definition to task.h
10101 - MINOR: activity: report context switch counts instead of rates
10102 - MINOR: threads: Implement HA_ATOMIC_LOAD().
10103 - BUG/MEDIUM: port_range: Make the ring buffer lock-free.
10104 - BUG/MEDIUM: listener: Fix how unlimited number of consecutive accepts is handled
10105 - MINOR: config: Test validity of tune.maxaccept during the config parsing
10106 - CLEANUP: config: Don't alter listener->maxaccept when nbproc is set to 1
10107 - BUG/MEDIUM: servers: fix typo "src" instead of "srv"
10108 - BUG/MEDIUM: ssl: Don't pretend we can retry a recv/send if we got a shutr/w.
10109 - BUG/MINOR: haproxy: fix rule->file memory leak
10110 - BUG/MINOR: log: properly free memory on logformat parse error and deinit()
10111 - BUG/MINOR: checks: free memory allocated for tasklets
10112 - BUG/MEDIUM: pattern: fix memory leak in regex pattern functions
10113 - BUG/MEDIUM: channels: Don't forget to reset output in channel_erase().
10114 - BUG/MEDIUM: connections: Make sure we remove CO_FL_SESS_IDLE on disown.
10115 - MINOR: threads: flatten the per-thread cpu-map
10116 - MINOR: init/threads: remove the useless tids[] array
10117 - MINOR: init/threads: make the threads array global
10118 - BUG/MEDIUM: ssl: Use the early_data API the right way.
10119 - BUG/MEDIUM: streams: Don't add CF_WRITE_ERROR if early data were rejected.
10120 - MEDIUM: streams: Add the ability to retry a request on L7 failure.
10121 - MEDIUM: streams: Add a way to replay failed 0rtt requests.
10122 - MEDIUM: streams: Add a new keyword for retry-on, "junk-response"
10123 - BUG/MINOR: stream: also increment the retry stats counter on L7 retries
10124 - BUG/MEDIUM: checks: make sure the warmup task takes the server lock
10125 - BUG/MINOR: logs/threads: properly split the log area upon startup
10126 - BUILD: extend travis-ci matrix
10127 - CLEANUP: Remove appsession documentation
10128 - DOC: Fix typo in keyword matrix
10129 - BUILD: remove "build_libressl" duplicate declaration
10130 - BUILD: travis-ci: get back to osx without openssl support
10131 - BUILD: enable several LibreSSL hacks, including
10132 - BUILD: temporarily mark LibreSSL builds as allowed to fail
10133 - BUILD: travis: TMPDIR replacement.
10134 - BUG/MEDIUM: ssl: Don't attempt to use early data with libressl.
10135 - MINOR: doc: Document allow-0rtt on the server line.
10136 - MINOR: doc: Document the interaction of allow-0rtt and retry-on 0rtt-rejected.
10137 - MEDIUM: proto: Change the prototype of the connect() method.
10138 - MEDIUM: tcp: add the "tfo" option to support TCP fastopen on the server
10139 - MINOR: config: Extract the code of "stick-table" line parsing.
10140 - BUILD/MINOR: stick-table: Compilation fix.
10141 - MEDIUM: stick-table: Stop handling stick-tables as proxies.
10142 - MINOR: stick-tables: Add peers process binding computing.
10143 - MINOR: stick-table: Add prefixes to stick-table names.
10144 - MINOR: peers: Do not emit global stick-table names.
10145 - DOC: Update for "table" lines in "peers" section.
10146 - REGTEST: Add reg tests for "table" lines in "peers" sections.
10147 - MEDIUM: regex: modify regex_comp() to atomically allocate/free the my_regex struct
10148 - REGTEST: make the tls_health_checks test much faster
10149 - REGTEST: make the "table in peers" test require v2.0
10150 - BUG/MINOR: mux-h2: rely on trailers output not input to turn them to empty data
10151 - BUG/MEDIUM: h2/htx: always fail on too large trailers
10152 - MEDIUM: mux-h2: discard contents that are to be sent after a shutdown
10153 - BUG/MEDIUM: mux-h2/htx: never wait for EOM when processing trailers
10154 - BUG/MEDIUM: h2/htx: never leave a trailers block alone with no EOM block
10155 - REGTEST: Flag some slow reg tests.
10156 - REGTEST: Reg tests file renaming.
10157 - REGTEST: Wrong renaming for one reg test.
10158 - REGTEST: Wrong assumption in IP:port logging test.
10159 - BUG/MINOR: mworker/ssl: close OpenSSL FDs on reload
10160 - MINOR: systemd: Use the variables from /etc/default/haproxy
10161 - MINOR: systemd: Make use of master socket in systemd unit
10162 - MINOR: systemd: support /etc/sysconfig/ for redhat based distrib
10163 - BUG/MEDIUM: stick-table: fix regression caused by a change in proxy struct
10164 - BUG/MEDIUM: tasks: fix possible segfault on task_destroy()
10165 - CLEANUP: task: remove unneeded tests before task_destroy()
10166 - MINOR: mworker: support a configurable maximum number of reloads
10167 - BUG/MINOR: mux-h2: fix the condition to close a cs-less h2s on the backend
10168 - BUG/MEDIUM: spoe: Be sure the sample is found before setting its context
10169 - BUG/MINOR: mux-h1: Fix the parsing of trailers
10170 - BUG/MINOR: htx: Never transfer more than expected in htx_xfer_blks()
10171 - MINOR: htx: Split on DATA blocks only when blocks are moved to an HTX message
10172 - MINOR: htx: Don't try to append a trailer block with the previous one
10173 - MINOR: htx: Remove support for unused OOB HTX blocks
10174 - BUILD: travis-ci bugfixes and improvements
10175 - BUG/MEDIUM: servers: Don't use the same srv flag for cookie-set and TFO.
10176 - BUG/MEDIUM: h2: Make sure we set send_list to NULL in h2_detach().
10177 - BUILD: ssl: fix again a libressl build failure after the openssl FD leak fix
10178 - CLEANUP: ssl-sock: use HA_OPENSSL_VERSION_NUMBER instead of OPENSSL_VERSION_NUMBER
10179 - BUILD: ssl: make libressl use its own version numbers
10180 - CLEANUP: ssl: remove 57 occurrences of useless tests on LIBRESSL_VERSION_NUMBER
10181 - MINOR: ssl: enable aes_gcm_dec on LibreSSL
10182 - BUILD: ssl: fix libressl build again after aes-gcm-enc
10183 - REORG: ssl: move openssl-compat from proto to common
10184 - REORG: ssl: move some OpenSSL defines from ssl_sock to openssl-compat
10185 - CLEANUP: ssl: never include openssl/*.h outside of openssl-compat.h anymore
10186 - CLEANUP: ssl: make inclusion of openssl headers safe
10187 - BUILD: add BoringSSL to travis-ci build matrix
10188 - BUILD: threads: Add __ha_cas_dw fallback for single threaded builds
10189 - BUG/MINOR: stream: Attach the read side on the response as soon as possible
10190 - BUG/MEDIUM: http: Use pointer to the begining of input to parse message headers
10191 - BUG/MEDIUM: h2: Don't check send_wait to know if we're in the send_list.
10192 - BUG/MEDIUM: streams: Make sur SI_FL_L7_RETRY is set before attempting a retry.
10193 - MEDIUM: streams: Add a new http action, disable-l7-retry.
10194 - MINOR: streams: Introduce a new retry-on keyword, all-retryable-errors.
10195 - BUG/MINOR: vars: Fix memory leak in vars_check_arg
10196 - BUILD: travis-ci: make TMPDIR global variable in travis-ci
10197 - CLEANUP: ssl: move the SSL_OP_* and SSL_MODE_* definitions to openssl-compat
10198 - CLEANUP: ssl: remove ifdef around SSL_CTX_get_extra_chain_certs()
10199 - CLEANUP: ssl: move all BIO_* definitions to openssl-compat
10200 - BUILD: threads: fix again the __ha_cas_dw() definition
10201 - BUG/MAJOR: mux-h2: do not add a stream twice to the send list
10202 - Revert "BUG/MINOR: vars: Fix memory leak in vars_check_arg"
10203 - BUG/MINOR: peers: Fix memory leak in cfg_parse_peers
10204 - BUG/MINOR: htx: make sure to always initialize the HTTP method when parsing a buffer
10205 - REGTEST: fix tls_health_checks random failures on MacOS in Travis-CI
10206 - MINOR: spoe: Set the argument chunk size to 0 when SPOE variables are checked
10207 - BUG/MINOR: vars: Fix memory leak in vars_check_arg
10208 - BUG/MAJOR: ssl: segfault upon an heartbeat request
10209 - MINOR: spoa-server: Clone the v1.7 spoa-example project
10210 - MINOR: spoa-server: move some definition from spoa_server.c to spoa_server.h
10211 - MINOR: spoa-server: Externalise debug functions
10212 - MINOR: spoe-server: rename "worker" functions
10213 - MINOR: spoa-server: Replace the thread init system by processes
10214 - MINOR: spoa-server: With debug mode, start only one process
10215 - MINOR: spoa-server: Allow registering external processes
10216 - MINOR: spoa-server: Allow registering message processors
10217 - MINOR: spoa-server: Load files
10218 - MINOR: spoa-server: Prepare responses
10219 - MINOR: spoa-server: Execute registered callbacks
10220 - MINOR: spoa-server: Add Lua processing
10221 - MINOR: spoa-server: Add python
10222 - MINOR/DOC: spoe-server: Add documentation
10223 - BUG/MEDIUM: connections: Don't forget to set xprt_ctx to NULL on close.
10224 - MINOR: lists: add LIST_ADDED() to check if an element belongs to a list
10225 - CLEANUP: mux-h2: use LIST_ADDED() instead of LIST_ISEMPTY() where relevant
10226 - MINOR: mux-h2: add two H2S flags to report the need for shutr/shutw
10227 - CLEANUP: mux-h2: simply use h2s->flags instead of ret in h2_deferred_shut()
10228 - CLEANUP: connection: remove the handle field from the wait_event struct
10229 - BUG/MINOR: log: Wrong log format initialization.
10230 - BUG/MINOR: mux-h2: make the do_shut{r,w} functions more robust against retries
10231 - BUG/MINOR: mworker: use after free when the PID not assigned
10232 - MINOR: mux-h2: remove useless test on stream ID vs last in wake function
10233 - MINOR: mux-h2: make h2_wake_some_streams() not depend on the CS flags
10234 - MINOR: mux-h2: make h2s_wake_one_stream() the only function to deal with CS
10235 - MINOR: mux-h2: make h2s_wake_one_stream() not depend on temporary CS flags
10236 - BUG/MINOR: mux-h2: make sure to honor KILL_CONN in do_shut{r,w}
10237 - CLEANUP: mux-h2: don't test for impossible CS_FL_REOS conditions
10238 - MINOR: mux-h2: add macros to check multiple stream states at once
10239 - MINOR: mux-h2: stop relying on CS_FL_REOS
10240 - BUG/MEDIUM: mux-h2: Set EOI on the conn_stream during h2_rcv_buf()
10241 - BUILD: debug: make gcc not complain on the ABORT_NOW() macro
10242 - MINOR: debug: add a new BUG_ON macro
10243 - MINOR: h2: Use BUG_ON() to enforce rules in subscribe/unsubscribe.
10244 - MINOR: h1: Use BUG_ON() to enforce rules in subscribe/unsubscribe.
10245 - MINOR: connections: Use BUG_ON() to enforce rules in subscribe/unsubscribe.
10246 - BUILD: ist: turn the lower/upper case tables to literal on obsolete linkers
10247
Willy Tarreau6e893b92019-03-26 05:40:51 +0100102482019/03/26 : 2.0-dev2
10249 - CLEANUP: http: Remove unreachable code in parse_http_req_capture
10250 - CLEANUP: stream: Remove bogus loop in conn_si_send_proxy
10251 - MINOR: lists: Implement locked variations.
10252 - MEDIUM: servers: Used a locked list for idle_orphan_conns.
10253 - MEDIUM: servers: Reorganize the way idle connections are cleaned.
10254 - BUG/MEDIUM: lists: Properly handle the case we're removing the first elt.
10255 - MINOR: cfgparse: Add a cast to make gcc happier.
10256 - BUG/MEDIUM: standard: Wrong reallocation size.
10257 - BUG/MINOR: listener: keep accept rate counters accurate under saturation
10258 - DOC: fix alphabetic ordering for "tune.fail-alloc" setting
10259 - MAJOR: config: disable support for nbproc and nbthread in parallel
10260 - MEDIUM: listener: keep a single thread-mask and warn on "process" misuse
10261 - MAJOR: listener: do not hold the listener lock in listener_accept()
10262 - MINOR: listener: maintain a per-thread count of the number of connections on a listener
10263 - MINOR: tools: implement functions to look up the nth bit set in a mask
10264 - MINOR: listener: pre-compute some thread counts per bind_conf
10265 - MINOR: listener: implement multi-queue accept for threads
10266 - MAJOR: listener: use the multi-queue for multi-thread listeners
10267 - MINOR: activity: add accept queue counters for pushed and overflows
10268 - MINOR: config: add global tune.listener.multi-queue setting
10269 - MAJOR: threads: enable one thread per CPU by default
10270 - DOC: update management.txt to reflect that threads are used by default
10271 - BUG/MINOR: config: don't over-count the global maxsock value
10272 - BUG/MEDIUM: list: fix the rollback on addq in the locked liss
10273 - BUG/MEDIUM: list: fix LIST_POP_LOCKED's removal of the last pointer
10274 - BUG/MEDIUM: list: add missing store barriers when updating elements and head
10275 - MINOR: list: make the delete and pop operations idempotent
10276 - MINOR: server: remove a few unneeded LIST_INIT calls after LIST_DEL_LOCKED
10277 - BUG/MEDIUM: listener: use a self-locked list for the dequeue lists
10278 - BUG/MEDIUM: listener: make sure the listener never accepts too many conns
10279 - BUG/MEDIUM: list: correct fix for LIST_POP_LOCKED's removal of last element
10280 - MINOR: listener: introduce listener_backlog() to report the backlog value
10281 - MINOR: listener: do not needlessly set l->maxconn
10282 - MINOR: proxy: do not change the listeners' maxconn when updating the frontend's
10283 - MEDIUM: config: don't enforce a low frontend maxconn value anymore
10284 - MINOR: peers: Add a message for heartbeat.
10285 - MINOR: global: keep a copy of the initial rlim_fd_cur and rlim_fd_max values
10286 - BUG/MINOR: init: never lower rlim_fd_max
10287 - BUG/MINOR: checks: make external-checks restore the original rlim_fd_cur/max
10288 - BUG/MINOR: mworker: be careful to restore the original rlim_fd_cur/max on reload
10289 - MINOR: init: make the maxpipe computation more accurate
10290 - MINOR: init: move some maxsock updates earlier
10291 - MEDIUM: init: make the global maxconn default to what rlim_fd_cur permits
10292 - REGTEST: fix a spurious "nbthread 4" in the connection test
10293 - DOC: update the text related to the global maxconn value
10294 - BUG/MAJOR: mux-h2: fix race condition between close on both ends
10295 - MINOR: sample: Replace "req.ungrpc" smp fetch by a "ungrpc" converter.
10296 - BUG/MEDIUM: list: fix again LIST_ADDQ_LOCKED
10297 - MINOR: htx: unconditionally handle parsing errors in requests or responses
10298 - MINOR: mux-h2: always pass HTX_FL_PARSING_ERROR between h2s and buf on RX
10299 - BUG/MEDIUM: h2/htx: verify that :path doesn't contain invalid chars
10300 - MINOR: sample: Code factorization "ungrpc" converter.
10301 - MINOR: sample: Rework gRPC converter code.
10302 - CLEANUP: wurfl: remove dead, broken and unmaintained code
10303 - MINOR: config: relax the range checks on cpu-map
10304 - BUG/MINOR: ssl: fix warning about ssl-min/max-ver support
10305 - MINOR: sample: Extract some protocol buffers specific code.
10306 - DOC: Remove tabs and fixed punctuation.
10307 - MINOR: sample: Add a protocol buffers specific converter.
10308 - REGTEST: Peers reg tests.
10309 - REGTEST: Enable reg tests with HEAD HTTP method usage.
10310 - MINOR: lists: add a LIST_DEL_INIT() macro
10311 - MINOR: task: use LIST_DEL_INIT() to remove a task from the queue
10312 - MINOR: listener: improve incoming traffic distribution
10313 - MINOR: tools: implement my_flsl()
10314 - MEDIUM: listener: change the LB algorithm again to use two round robins instead
10315 - CLEANUP: listener: remove old thread bit mapping
10316 - MINOR: listener: move thr_idx from the bind_conf to the listener
10317 - BUG/MEDIUM: logs: Only attempt to free startup_logs once.
10318 - BUG/MAJOR: config: Wrong maxconn adjustment.
10319 - BUG/MEDIUM: 51d: fix possible segfault on deinit_51degrees()
10320 - OPTIM: task: limit the impact of memory barriers in taks_remove_from_task_list()
10321 - MINOR: fd: Remove debugging code.
10322 - BUG/MEDIUM: listeners: Don't call fd_stop_recv() if fd_updt is NULL.
10323 - MINOR: threads: Implement __ha_barrier_atomic*.
10324 - MEDIUM: threads: Use __ATOMIC_SEQ_CST when using the newer atomic API.
10325 - MINOR: threads: Add macros to do atomic operation with no memory barrier.
10326 - MEDIUM: various: Use __ha_barrier_atomic* when relevant.
10327 - MEDIUM: applets: Use the new _HA_ATOMIC_* macros.
10328 - MEDIUM: xref: Use the new _HA_ATOMIC_* macros.
10329 - MEDIUM: fd: Use the new _HA_ATOMIC_* macros.
10330 - MEDIUM: freq_ctr: Use the new _HA_ATOMIC_* macros.
10331 - MEDIUM: proxy: Use the new _HA_ATOMIC_* macros.
10332 - MEDIUM: server: Use the new _HA_ATOMIC_* macros.
10333 - MEDIUM: task: Use the new _HA_ATOMIC_* macros.
10334 - MEDIUM: activity: Use the new _HA_ATOMIC_* macros.
10335 - MEDIUM: backend: Use the new _HA_ATOMIC_* macros.
10336 - MEDIUM: cache: Use the new _HA_ATOMIC_* macros.
10337 - MEDIUM: checks: Use the new _HA_ATOMIC_* macros.
10338 - MEDIUM: pollers: Use the new _HA_ATOMIC_* macros.
10339 - MEDIUM: compression: Use the new _HA_ATOMIC_* macros.
10340 - MEDIUM: spoe: Use the new _HA_ATOMIC_* macros.
10341 - MEDIUM: threads: Use the new _HA_ATOMIC_* macros.
10342 - MEDIUM: http: Use the new _HA_ATOMIC_* macros.
10343 - MEDIUM: lb/threads: Use the new _HA_ATOMIC_* macros.
10344 - MEDIUM: listeners: Use the new _HA_ATOMIC_* macros.
10345 - MEDIUM: logs: Use the new _HA_ATOMIC_* macros.
10346 - MEDIUM: memory: Use the new _HA_ATOMIC_* macros.
10347 - MEDIUM: peers: Use the new _HA_ATOMIC_* macros.
10348 - MEDIUM: proto_tcp: Use the new _HA_ATOMIC_* macros.
10349 - MEDIUM: queues: Use the new _HA_ATOMIC_* macros.
10350 - MEDIUM: sessions: Use the new _HA_ATOMIC_* macros.
10351 - MEDIUM: ssl: Use the new _HA_ATOMIC_* macros.
10352 - MEDIUM: stream: Use the new _HA_ATOMIC_* macros.
10353 - MEDIUM: tcp_rules: Use the new _HA_ATOMIC_* macros.
10354 - MEDIUM: time: Use the new _HA_ATOMIC_* macros.
10355 - MEDIUM: vars: Use the new _HA_ATOMIC_* macros.
10356 - MINOR: config: remove obsolete use of DEFAULT_MAXCONN at various places
10357 - MINOR: config: continue to rely on DEFAULT_MAXCONN to set the minimum maxconn
10358 - BUG/MEDIUM: list: fix incorrect pointer unlocking in LIST_DEL_LOCKED()
10359 - BUG/MEDIUM: listener: make sure we don't pick stopped threads
10360 - MEDIUM: list: Remove useless barriers.
10361 - MEDIUM: list: Use _HA_ATOMIC_*
10362 - MEDIUM: connections: Use _HA_ATOMIC_*
10363 - BUG/MAJOR: tasks: Use the TASK_GLOBAL flag to know if we're in the global rq.
10364 - BUG/MEDIUM: threads/fd: do not forget to take into account epoll_fd/pipes
10365 - BUG/MEDIUM: init/threads: consider epoll_fd/pipes for automatic maxconn calculation
10366 - BUG/MEDIUM: tasks: Make sure we wake sleeping threads if needed.
10367 - BUG/MINOR: mux-h1: Don't report an error on EOS if no message was received
10368 - BUG/MINOR: stats/htx: Call channel_add_input() when response headers are sent
10369 - BUG/MINOR: lua/htx: Use channel_add_input() when response data are added
10370 - BUG/MINOR: lua/htx: Don't forget to call htx_to_buf() when appropriate
10371 - MINOR: stats: Add the status code STAT_STATUS_IVAL to handle invalid requests
10372 - MINOR: stats: Move stuff about the stats status codes in stats files
10373 - BUG/MINOR: stats: Be more strict on what is a valid request to the stats applet
10374 - Revert "REGTEST: Enable reg tests with HEAD HTTP method usage."
10375 - BUILD: listener: shut up a build warning when threads are disabled
10376 - BUILD: Makefile: allow the reg-tests target to be verbose
10377 - BUILD: Makefile: resolve LEVEL before calling run-regtests
10378 - BUG/MAJOR: spoe: Fix initialization of thread-dependent fields
10379 - BUG/MAJOR: stats: Fix how huge POST data are read from the channel
10380 - BUG/MINOR: http/counters: fix missing increment of fe->srv_aborts
10381 - BUG/MEDIUM: mux-h2: Always wakeup streams with no id to avoid frozen streams
10382 - MINOR: mux-h2: Set REFUSED_STREAM error to reset a stream if no data was never sent
10383 - MINOR: muxes: Report the Last read with a dedicated flag
10384 - MINOR: proto-http/proto-htx: Make error handling clearer during data forwarding
10385 - BUILD: tools: fix a build warning on some 32-bit archs
10386 - MINOR: init: report the list of optionally available services
10387 - MEDIUM: proto_htx: Switch to infinite forwarding if there is no data filter
10388 - BUG/MINOR: cache: Fully consume large requests in the cache applet
10389 - BUG/MINOR: stats: Fully consume large requests in the stats applet
10390 - BUG/MEDIUM: lua: Fully consume large requests when an HTTP applet ends
10391 - MINOR: proto_http: Add function to handle the header "Expect: 100-continue"
10392 - MINOR: proto_htx: Add function to handle the header "Expect: 100-continue"
10393 - MINOR: stats/cache: Handle the header Expect when applets are registered
10394 - MINOR: http/applets: Handle all applets intercepting HTTP requests the same way
10395 - CLEANUP: cache: don't export http_cache_applet anymore
10396 - MINOR: lua: Don't handle the header Expect in lua HTTP applets anymore
10397 - BUG/MINOR: doc: Be accurate on the behavior on pool-purge-delay.
10398 - Revert "MEDIUM: proto_htx: Switch to infinite forwarding if there is no data filter"
10399 - BUG/MEDIUM: mux-h2: Make sure we destroyed the h2s once shutr/shutw is done.
10400 - BUG/MEDIUM: mux-h2: Don't bother keeping the h2s if detaching and nothing to send.
10401 - BUG/MEDIUM: mux-h2: Use the right list in h2_stop_senders().
10402 - MINOR: mux-h2: copy small data blocks more often and reduce the number of pauses
10403 - CLEANUP: mux-h2: add some comments to help understand the code
10404 - BUG/MEDIUM: ssl: ability to set TLS 1.3 ciphers using ssl-default-server-ciphersuites
10405 - BUG/MINOR: log: properly format IPv6 address when LOG_OPT_HEXA modifier is used.
10406 - BUG/MEDIUM: h2: Try to be fair when sending data.
10407 - BUG/MINOR: proto-http: Don't forward request body anymore on error
10408 - MINOR: mux-h2: Remove useless test on ES flag in h2_frt_transfer_data()
10409 - MINOR: connection: and new flag to mark end of input (EOI)
10410 - MINOR: channel: Report EOI on the input channel if it was reached in the mux
10411 - MEDIUM: mux-h2: Don't mix the end of the message with the end of stream
10412 - MINOR: mux-h1: Set CS_FL_EOI the end of the message is reached
10413 - BUG/MEDIUM: http/htx: Fix handling of the option abortonclose
10414 - CLEANUP: muxes/stream-int: Remove flags CS_FL_READ_NULL and SI_FL_READ_NULL
10415 - MEDIUM: proto_htx: Reintroduce the infinite forwarding on data
10416 - BUG/MEDIUM: h2: only destroy the h2s if h2s->cs is NULL.
10417 - BUG/MEDIUM: h2: Use the new sending_list in h2s_notify_send().
10418 - BUG/MEDIUM: h2: Follow the same logic in h2_deferred_shut than in h2_snd_buf.
10419 - BUG/MEDIUM: h2: Remove the tasklet from the task list if unsubscribing.
10420 - BUG/MEDIUM: task/h2: add an idempotent task removal fucntion
10421 - CLEANUP: task: only perform a LIST_DEL() when the list is not empty
10422 - BUG/MEDIUM: mux-h2: make sure to always notify streams of EOS condition
10423 - CONTRIB: debug: report the CS and CF's EOI flags
10424 - MINOR: channel: don't unset CF_SHUTR_NOW after shutting down.
10425
Willy Tarreau6c1b6672019-02-26 16:43:49 +0100104262019/02/26 : 2.0-dev1
10427 - MINOR: mux-h2: only increase the connection window with the first update
10428 - REGTESTS: remove the expected window updates from H2 handshakes
10429 - BUG/MINOR: mux-h2: make empty HEADERS frame return a connection error
10430 - BUG/MEDIUM: mux-h2: mark that we have too many CS once we have more than the max
10431 - MEDIUM: mux-h2: remove padlen during headers phase
10432 - MINOR: h2: add a bit-based frame type representation
10433 - MINOR: mux-h2: remove useless check for empty frame length in h2s_decode_headers()
10434 - MEDIUM: mux-h2: decode HEADERS frames before allocating the stream
10435 - MINOR: mux-h2: make h2c_send_rst_stream() use the dummy stream's error code
10436 - MINOR: mux-h2: add a new dummy stream for the REFUSED_STREAM error code
10437 - MINOR: mux-h2: fail stream creation more cleanly using RST_STREAM
10438 - MINOR: buffers: add a new b_move() function
10439 - MINOR: mux-h2: make h2_peek_frame_hdr() support an offset
10440 - MEDIUM: mux-h2: handle decoding of CONTINUATION frames
10441 - CLEANUP: mux-h2: remove misleading comments about CONTINUATION
10442 - BUG/MEDIUM: servers: Don't try to reuse connection if we switched server.
10443 - BUG/MEDIUM: tasks: Decrement tasks_run_queue in tasklet_free().
10444 - BUG/MINOR: htx: send the proper authenticate header when using http-request auth
10445 - BUG/MEDIUM: mux_h2: Don't add to the idle list if we're full.
10446 - BUG/MEDIUM: servers: Fail if we fail to allocate a conn_stream.
10447 - BUG/MAJOR: servers: Use the list api correctly to avoid crashes.
10448 - BUG/MAJOR: servers: Correctly use LIST_ELEM().
10449 - BUG/MAJOR: sessions: Use an unlimited number of servers for the conn list.
10450 - BUG/MEDIUM: servers: Flag the stream_interface on handshake error.
10451 - MEDIUM: servers: Be smarter when switching connections.
10452 - MEDIUM: sessions: Keep track of which connections are idle.
10453 - MINOR: payload: add sample fetch for TLS ALPN
10454 - BUG/MEDIUM: log: don't mark log FDs as non-blocking on terminals
10455 - MINOR: channel: Add the function channel_add_input
10456 - MINOR: stats/htx: Call channel_add_input instead of updating channel state by hand
10457 - BUG/MEDIUM: cache: Be sure to end the forwarding when XFER length is unknown
10458 - BUG/MAJOR: htx: Return the good block address after a defrag
10459 - MINOR: lb: allow redispatch when using consistent hash
10460 - CLEANUP: mux-h2: fix end-of-stream flag name when processing headers
10461 - BUG/MEDIUM: mux-h2: always restart reading if data are available
10462 - BUG/MINOR: mux-h2: set the stream-full flag when leaving h2c_decode_headers()
10463 - BUG/MINOR: mux-h2: don't check the CS count in h2c_bck_handle_headers()
10464 - BUG/MINOR: mux-h2: mark end-of-stream after processing response HEADERS, not before
10465 - BUG/MINOR: mux-h2: only update rxbuf's length for H1 headers
10466 - BUG/MEDIUM: mux-h1: use per-direction flags to indicate transitions
10467 - BUG/MEDIUM: mux-h1: make HTX chunking consistent with H2
10468 - BUG/MAJOR: stream-int: Update the stream expiration date in stream_int_notify()
10469 - BUG/MEDIUM: proto-htx: Set SI_FL_NOHALF on server side when request is done
10470 - BUG/MEDIUM: mux-h1: Add a task to handle connection timeouts
10471 - MINOR: mux-h2: make h2c_decode_headers() return a status, not a count
10472 - MINOR: mux-h2: add a new dummy stream : h2_error_stream
10473 - MEDIUM: mux-h2: make h2c_decode_headers() support recoverable errors
10474 - BUG/MINOR: mux-h2: detect when the HTX EOM block cannot be added after headers
10475 - MINOR: mux-h2: remove a misleading and impossible test
10476 - CLEANUP: mux-h2: clean the stream error path on HEADERS frame processing
10477 - MINOR: mux-h2: check for too many streams only for idle streams
10478 - MINOR: mux-h2: set H2_SF_HEADERS_RCVD when a HEADERS frame was decoded
10479 - BUG/MEDIUM: mux-h2: decode trailers in HEADERS frames
10480 - MINOR: h2: add h2_make_h1_trailers to turn H2 headers to H1 trailers
10481 - MEDIUM: mux-h2: pass trailers to H1 (legacy mode)
10482 - MINOR: htx: add a new function to add a block without filling it
10483 - MINOR: h2: add h2_make_htx_trailers to turn H2 headers to HTX trailers
10484 - MEDIUM: mux-h2: pass trailers to HTX
10485 - MINOR: mux-h1: parse the content-length header on output and set H1_MF_CLEN
10486 - BUG/MEDIUM: mux-h1: don't enforce chunked encoding on requests
10487 - MINOR: mux-h2: make HTX_BLK_EOM processing idempotent
10488 - MINOR: h1: make the H1 headers block parser able to parse headers only
10489 - MEDIUM: mux-h2: emit HEADERS frames when facing HTX trailers blocks
10490 - MINOR: stream/htx: Add info about the HTX structs in "show sess all" command
10491 - MINOR: stream: Add the subscription events of SIs in "show sess all" command
10492 - MINOR: mux-h1: Add the subscription events in "show fd" command
10493 - BUG/MEDIUM: h1: Get the h1m state when restarting the headers parsing
10494 - BUG/MINOR: cache/htx: Be sure to count partial trailers
10495 - BUG/MEDIUM: h1: In h1_init(), wake the tasklet instead of calling h1_recv().
10496 - BUG/MEDIUM: server: Defer the mux init until after xprt has been initialized.
10497 - MINOR: connections: Remove a stall comment.
10498 - BUG/MEDIUM: cli: make "show sess" really thread-safe
10499 - BUILD: add a new file "version.c" to carry version updates
10500 - MINOR: stream/htx: add the HTX flags output in "show sess all"
10501 - MINOR: stream/cli: fix the location of the waiting flag in "show sess all"
10502 - MINOR: stream/cli: report more info about the HTTP messages on "show sess all"
10503 - BUG/MINOR: lua: bad args are returned for Lua actions
10504 - BUG/MEDIUM: lua: dead lock when Lua tasks are trigerred
10505 - MINOR: htx: Add an helper function to get the max space usable for a block
10506 - MINOR: channel/htx: Add HTX version for some helper functions
10507 - BUG/MEDIUM: cache/htx: Respect the reserve when cached objects are served
10508 - BUG/MINOR: stats/htx: Respect the reserve when the stats page is dumped
10509 - DOC: regtest: make it clearer what the purpose of the "broken" series is
10510 - REGTEST: mailers: add new test for 'mailers' section
10511 - REGTEST: Add a reg test for health-checks over SSL/TLS.
10512 - BUG/MINOR: mux-h1: Close connection on shutr only when shutw was really done
10513 - MEDIUM: mux-h1: Clarify how shutr/shutw are handled
10514 - BUG/MINOR: compression: Disable it if another one is already in progress
10515 - BUG/MINOR: filters: Detect cache+compression config on legacy HTTP streams
10516 - BUG/MINOR: cache: Disable the cache if any compression filter precedes it
10517 - REGTEST: Add some informatoin to test results.
10518 - MINOR: htx: Add a function to truncate all blocks after a specific offset
10519 - MINOR: channel/htx: Add the HTX version of channel_truncate/erase
10520 - BUG/MINOR: proto_htx: Use HTX versions to truncate or erase a buffer
10521 - BUG/CRITICAL: mux-h2: re-check the frame length when PRIORITY is used
10522 - DOC: Fix typo in req.ssl_alpn example (commit 4afdd138424ab...)
10523 - DOC: http-request cache-use / http-response cache-store expects cache name
10524 - REGTEST: "capture (request|response)" regtest.
10525 - BUG/MINOR: lua/htx: Respect the reserve when data are send from an HTX applet
10526 - REGTEST: filters: add compression test
10527 - BUG/MEDIUM: init: Initialize idle_orphan_conns for first server in server-template
10528 - BUG/MEDIUM: ssl: Disable anti-replay protection and set max data with 0RTT.
10529 - DOC: Be a bit more explicit about allow-0rtt security implications.
10530 - MINOR: mux-h1: make the mux_h1_ops struct static
10531 - BUILD: makefile: add an EXTRA_OBJS variable to help build optional code
10532 - BUG/MEDIUM: connection: properly unregister the mux on failed initialization
10533 - BUG/MAJOR: cache: fix confusion between zero and uninitialized cache key
10534 - REGTESTS: test case for map_regm commit 271022150d
10535 - REGTESTS: Basic tests for concat,strcmp,word,field,ipmask converters
10536 - REGTESTS: Basic tests for using maps to redirect requests / select backend
10537 - DOC: REGTESTS README varnishtest -Dno-htx= define.
10538 - MINOR: spoe: Make the SPOE filter compatible with HTX proxies
10539 - MINOR: checks: Store the proxy in checks.
10540 - BUG/MEDIUM: checks: Avoid having an associated server for email checks.
10541 - REGTEST: Switch to vtest.
10542 - REGTEST: Adapt reg test doc files to vtest.
10543 - BUG/MEDIUM: h1: Make sure we destroy an inactive connectin that did shutw.
10544 - BUG/MINOR: base64: dec func ignores padding for output size checking
10545 - BUG/MEDIUM: ssl: missing allocation failure checks loading tls key file
10546 - MINOR: ssl: add support of aes256 bits ticket keys on file and cli.
10547 - BUG/MINOR: backend: don't use url_param_name as a hint for BE_LB_ALGO_PH
10548 - BUG/MINOR: backend: balance uri specific options were lost across defaults
10549 - BUG/MINOR: backend: BE_LB_LKUP_CHTREE is a value, not a bit
10550 - MINOR: backend: move url_param_name/len to lbprm.arg_str/len
10551 - MINOR: backend: make headers and RDP cookie also use arg_str/len
10552 - MINOR: backend: add new fields in lbprm to store more LB options
10553 - MINOR: backend: make the header hash use arg_opt1 for use_domain_only
10554 - MINOR: backend: remap the balance uri settings to lbprm.arg_opt{1,2,3}
10555 - MINOR: backend: move hash_balance_factor out of chash
10556 - MEDIUM: backend: move all LB algo parameters into an union
10557 - MINOR: backend: make the random algorithm support a number of draws
10558 - BUILD/MEDIUM: da: Necessary code changes for new buffer API.
10559 - BUG/MINOR: stick_table: Prevent conn_cur from underflowing
10560 - BUG: 51d: Changes to the buffer API in 1.9 were not applied to the 51Degrees code.
10561 - BUG/MEDIUM: stats: Get the right scope pointer depending on HTX is used or not
10562 - DOC: add a missing space in the documentation for bc_http_major
10563 - REGTEST: checks basic stats webpage functionality
10564 - BUG/MEDIUM: servers: Make assign_tproxy_address work when ALPN is set.
10565 - BUG/MEDIUM: connections: Add the CO_FL_CONNECTED flag if a send succeeded.
10566 - DOC: add github issue templates
10567 - MINOR: cfgparse: Extract some code to be re-used.
10568 - CLEANUP: cfgparse: Return asap from cfg_parse_peers().
10569 - CLEANUP: cfgparse: Code reindentation.
10570 - MINOR: cfgparse: Useless frontend initialization in "peers" sections.
10571 - MINOR: cfgparse: Rework peers frontend init.
10572 - MINOR: cfgparse: Simplication.
10573 - MINOR: cfgparse: Make "peer" lines be parsed as "server" lines.
10574 - MINOR: peers: Make outgoing connection to SSL/TLS peers work.
10575 - MINOR: cfgparse: SSL/TLS binding in "peers" sections.
10576 - DOC: peers: SSL/TLS documentation for "peers"
10577 - BUG/MINOR: startup: certain goto paths in init_pollers fail to free
10578 - BUG/MEDIUM: checks: fix recent regression on agent-check making it crash
10579 - BUG/MINOR: server: don't always trust srv_check_health when loading a server state
10580 - BUG/MINOR: check: Wake the check task if the check is finished in wake_srv_chk()
10581 - BUG/MEDIUM: ssl: Fix handling of TLS 1.3 KeyUpdate messages
10582 - DOC: mention the effect of nf_conntrack_tcp_loose on src/dst
10583 - BUG/MINOR: proto-htx: Return an error if all headers cannot be received at once
10584 - BUG/MEDIUM: mux-h2/htx: Respect the channel's reserve
10585 - BUG/MINOR: mux-h1: Apply the reserve on the channel's buffer only
10586 - BUG/MINOR: mux-h1: avoid copying output over itself in zero-copy
10587 - BUG/MAJOR: mux-h2: don't destroy the stream on failed allocation in h2_snd_buf()
10588 - BUG/MEDIUM: backend: also remove from idle list muxes that have no more room
10589 - BUG/MEDIUM: mux-h2: properly abort on trailers decoding errors
10590 - MINOR: h2: declare new sets of frame types
10591 - BUG/MINOR: mux-h2: CONTINUATION in closed state must always return GOAWAY
10592 - BUG/MINOR: mux-h2: headers-type frames in HREM are always a connection error
10593 - BUG/MINOR: mux-h2: make it possible to set the error code on an already closed stream
10594 - BUG/MINOR: hpack: return a compression error on invalid table size updates
10595 - MINOR: server: make sure pool-max-conn is >= -1
10596 - BUG/MINOR: stream: take care of synchronous errors when trying to send
10597 - CLEANUP: server: fix indentation mess on idle connections
10598 - BUG/MINOR: mux-h2: always check the stream ID limit in h2_avail_streams()
10599 - BUG/MINOR: mux-h2: refuse to allocate a stream with too high an ID
10600 - BUG/MEDIUM: backend: never try to attach to a mux having no more stream available
10601 - MINOR: server: add a max-reuse parameter
10602 - MINOR: mux-h2: always consider a server's max-reuse parameter
10603 - MEDIUM: stream-int: always mark pending outgoing SI_ST_CON
10604 - MINOR: stream: don't wait before retrying after a failed connection reuse
10605 - MEDIUM: h2: always parse and deduplicate the content-length header
10606 - BUG/MINOR: mux-h2: always compare content-length to the sum of DATA frames
10607 - CLEANUP: h2: Remove debug printf in mux_h2.c
10608 - MINOR: cfgparse: make the process/thread parser support a maximum value
10609 - MINOR: threads: make MAX_THREADS configurable at build time
10610 - DOC: nbthread is no longer experimental.
10611 - BUG/MINOR: listener: always fill the source address for accepted socketpairs
10612 - BUG/MINOR: mux-h2: do not report available outgoing streams after GOAWAY
10613 - BUG/MINOR: spoe: corrected fragmentation string size
10614 - BUG/MINOR: task: fix possibly missed event in inter-thread wakeups
10615 - BUG/MEDIUM: servers: Attempt to reuse an unfinished connection on retry.
10616 - BUG/MEDIUM: backend: always call si_detach_endpoint() on async connection failure
10617 - SCRIPTS: add the issue tracker URL to the announce script
10618 - MINOR: peers: Extract some code to be reused.
10619 - CLEANUP: peers: Indentation fixes.
10620 - MINOR: peers: send code factorization.
10621 - MINOR: peers: Add new functions to send code and reduce the I/O handler.
10622 - MEDIUM: peers: synchronizaiton code factorization to reduce the size of the I/O handler.
10623 - MINOR: peers: Move update receive code to reduce the size of the I/O handler.
10624 - MINOR: peers: Move ack, switch and definition receive code to reduce the size of the I/O handler.
10625 - MINOR: peers: Move high level receive code to reduce the size of I/O handler.
10626 - CLEANUP: peers: Be more generic.
10627 - MINOR: peers: move error handling to reduce the size of the I/O handler.
10628 - MINOR: peers: move messages treatment code to reduce the size of the I/O handler.
10629 - MINOR: peers: move send code to reduce the size of the I/O handler.
10630 - CLEANUP: peers: Remove useless statements.
10631 - MINOR: peers: move "hello" message treatment code to reduce the size of the I/O handler.
10632 - MINOR: peers: move peer initializations code to reduce the size of the I/O handler.
10633 - CLEANUP: peers: factor the error handling code in peer_treet_updatemsg()
10634 - CLEANUP: peers: factor error handling in peer_treat_definedmsg()
10635 - BUILD/MINOR: peers: shut up a build warning introduced during last cleanup
10636 - BUG/MEDIUM: mux-h2: only close connection on request frames on closed streams
10637 - CLEANUP: mux-h2: remove two useless but misleading assignments
10638 - BUG/MEDIUM: checks: Check that conn_install_mux succeeded.
10639 - BUG/MEDIUM: servers: Only destroy a conn_stream we just allocated.
10640 - BUG/MEDIUM: servers: Don't add an incomplete conn to the server idle list.
10641 - BUG/MEDIUM: checks: Don't try to set ALPN if connection failed.
10642 - BUG/MEDIUM: h2: In h2_send(), stop the loop if we failed to alloc a buf.
10643 - BUG/MEDIUM: peers: Handle mux creation failure.
10644 - BUG/MEDIUM: servers: Close the connection if we failed to install the mux.
10645 - BUG/MEDIUM: compression: Rewrite strong ETags
10646 - BUG/MINOR: deinit: tcp_rep.inspect_rules not deinit, add to deinit
10647 - CLEANUP: mux-h2: remove misleading leftover test on h2s' nullity
10648 - BUG/MEDIUM: mux-h2: wake up flow-controlled streams on initial window update
10649 - BUG/MEDIUM: mux-h2: fix two half-closed to closed transitions
10650 - BUG/MEDIUM: mux-h2: make sure never to send GOAWAY on too old streams
10651 - BUG/MEDIUM: mux-h2: do not abort HEADERS frame before decoding them
10652 - BUG/MINOR: mux-h2: make sure response HEADERS are not received in other states than OPEN and HLOC
10653 - MINOR: h2: add a generic frame checker
10654 - MEDIUM: mux-h2: check the frame validity before considering the stream state
10655 - CLEANUP: mux-h2: remove stream ID and frame length checks from the frame parsers
10656 - BUG/MINOR: mux-h2: make sure request trailers on aborted streams don't break the connection
10657 - DOC: compression: Update the reasons for disabled compression
10658 - BUG/MEDIUM: buffer: Make sure b_is_null handles buffers waiting for allocation.
10659 - DOC: htx: make it clear that htxbuf() and htx_from_buf() always return valid pointers
10660 - MINOR: htx: never check for null htx pointer in htx_is_{,not_}empty()
10661 - MINOR: mux-h2: consistently rely on the htx variable to detect the mode
10662 - BUG/MEDIUM: peers: Peer addresses parsing broken.
10663 - BUG/MEDIUM: mux-h1: Don't add "transfer-encoding" if message-body is forbidden
10664 - BUG/MEDIUM: connections: Don't forget to remove CO_FL_SESS_IDLE.
10665 - BUG/MINOR: stream: don't close the front connection when facing a backend error
10666 - BUG/MEDIUM: mux-h2: wait for the mux buffer to be empty before closing the connection
10667 - MINOR: stream-int: add a new flag to mention that we want the connection to be killed
10668 - MINOR: connstream: have a new flag CS_FL_KILL_CONN to kill a connection
10669 - BUG/MEDIUM: mux-h2: do not close the connection on aborted streams
10670 - BUG/MINOR: server: fix logic flaw in idle connection list management
10671 - MINOR: mux-h2: max-concurrent-streams should be unsigned
10672 - MINOR: mux-h2: make sure to only check concurrency limit on the frontend
10673 - MINOR: mux-h2: learn and store the peer's advertised MAX_CONCURRENT_STREAMS setting
10674 - BUG/MEDIUM: mux-h2: properly consider the peer's advertised max-concurrent-streams
10675 - MINOR: xref: Add missing barriers.
10676 - MINOR: muxes: Don't bother to LIST_DEL(&conn->list) before calling conn_free().
10677 - MINOR: debug: Add an option that causes random allocation failures.
10678 - BUG/MEDIUM: backend: always release the previous connection into its own target srv_list
10679 - BUG/MEDIUM: htx: check the HTX compatibility in dynamic use-backend rules
10680 - BUG/MINOR: tune.fail-alloc: Don't forget to initialize ret.
10681 - BUG/MINOR: backend: check srv_conn before dereferencing it
10682 - BUG/MEDIUM: mux-h2: always omit :scheme and :path for the CONNECT method
10683 - BUG/MEDIUM: mux-h2: always set :authority on request output
10684 - BUG/MEDIUM: stream: Don't forget to free s->unique_id in stream_free().
10685 - BUG/MINOR: threads: fix the process range of thread masks
10686 - BUG/MINOR: config: fix bind line thread mask validation
10687 - CLEANUP: threads: fix misleading comment about all_threads_mask
10688 - CLEANUP: threads: use nbits to calculate the thread mask
10689 - OPTIM: listener: optimize cache-line packing for struct listener
10690 - MINOR: tools: improve the popcount() operation
10691 - MINOR: config: keep an all_proc_mask like we have all_threads_mask
10692 - MINOR: global: add proc_mask() and thread_mask()
10693 - MINOR: config: simplify bind_proc processing using proc_mask()
10694 - MINOR: threads: make use of thread_mask() to simplify some thread calculations
10695 - BUG/MINOR: compression: properly report compression stats in HTX mode
10696 - BUG/MINOR: task: close a tiny race in the inter-thread wakeup
10697 - BUG/MAJOR: config: verify that targets of track-sc and stick rules are present
10698 - BUG/MAJOR: spoe: verify that backends used by SPOE cover all their callers' processes
10699 - BUG/MAJOR: htx/backend: Make all tests on HTTP messages compatible with HTX
10700 - BUG/MINOR: config: make sure to count the error on incorrect track-sc/stick rules
10701 - DOC: ssl: Clarify when pre TLSv1.3 cipher can be used
10702 - DOC: ssl: Stop documenting ciphers example to use
10703 - BUG/MINOR: spoe: do not assume agent->rt is valid on exit
10704 - BUG/MINOR: lua: initialize the correct idle conn lists for the SSL sockets
10705 - BUG/MEDIUM: spoe: initialization depending on nbthread must be done last
10706 - BUG/MEDIUM: server: initialize the idle conns list after parsing the config
10707 - BUG/MEDIUM: server: initialize the orphaned conns lists and tasks at the end
10708 - MINOR: config: make MAX_PROCS configurable at build time
10709 - BUG/MAJOR: spoe: Don't try to get agent config during SPOP healthcheck
10710 - BUG/MINOR: config: Reinforce validity check when a process number is parsed
10711 - BUG/MEDIUM: peers: check that p->srv actually exists before using p->srv->use_ssl
10712 - CONTRIB: contrib/prometheus-exporter: Add a Prometheus exporter for HAProxy
10713 - BUG/MINOR: mux-h1: verify the request's version before dropping connection: keep-alive
10714 - BUG: 51d: In Hash Trie, multi header matching was affected by the header names stored globaly.
10715 - MEDIUM: 51d: Enabled multi threaded operation in the 51Degrees module.
10716 - BUG/MAJOR: stream: avoid double free on unique_id
10717 - BUILD/MINOR: stream: avoid a build warning with threads disabled
10718 - BUILD/MINOR: tools: fix build warning in the date conversion functions
10719 - BUILD/MINOR: peers: remove an impossible null test in intencode()
10720 - BUILD/MINOR: htx: fix some potential null-deref warnings with http_find_stline
10721 - BUG/MEDIUM: peers: Missing peer initializations.
10722 - BUG/MEDIUM: http_fetch: fix the "base" and "base32" fetch methods in HTX mode
10723 - BUG/MEDIUM: proto_htx: Fix data size update if end of the cookie is removed
10724 - BUG/MEDIUM: http_fetch: fix "req.body_len" and "req.body_size" fetch methods in HTX mode
10725 - BUILD/MEDIUM: initcall: Fix build on MacOS.
10726 - BUG/MEDIUM: mux-h2/htx: Always set CS flags before exiting h2_rcv_buf()
10727 - MINOR: h2/htx: Set the flag HTX_SL_F_BODYLESS for messages without body
10728 - BUG/MINOR: mux-h1: Add "transfer-encoding" header on outgoing requests if needed
10729 - BUG/MINOR: mux-h2: Don't add ":status" pseudo-header on trailers
10730 - BUG/MINOR: proto-htx: Consider a XFER_LEN message as chunked by default
10731 - BUG/MEDIUM: h2/htx: Correctly handle interim responses when HTX is enabled
10732 - MINOR: mux-h2: Set HTX extra value when possible
10733 - BUG/MEDIUM: htx: count the amount of copied data towards the final count
10734 - MINOR: mux-h2: make the H2 MAX_FRAME_SIZE setting configurable
10735 - BUG/MEDIUM: mux-h2/htx: send an empty DATA frame on empty HTX trailers
10736 - BUG/MEDIUM: servers: Use atomic operations when handling curr_idle_conns.
10737 - BUG/MEDIUM: servers: Add a per-thread counter of idle connections.
10738 - MINOR: fd: add a new my_closefrom() function to close all FDs
10739 - MINOR: checks: use my_closefrom() to close all FDs
10740 - MINOR: fd: implement an optimised my_closefrom() function
10741 - BUG/MINOR: fd: make sure my_closefrom() doesn't miss some FDs
10742 - BUG/MAJOR: fd/threads, task/threads: ensure all spin locks are unlocked
10743 - BUG/MAJOR: listener: Make sure the listener exist before using it.
10744 - MINOR: fd: Use closefrom() as my_closefrom() if supported.
10745 - BUG/MEDIUM: mux-h1: Report the right amount of data xferred in h1_rcv_buf()
10746 - BUG/MINOR: channel: Set CF_WROTE_DATA when outgoing data are skipped
10747 - MINOR: htx: Add function to drain data from an HTX message
10748 - MINOR: channel/htx: Add function to skips output bytes from an HTX channel
10749 - BUG/MAJOR: cache/htx: Set the start-line offset when a cached object is served
10750 - BUG/MEDIUM: cache: Get objects from the cache only for GET and HEAD requests
10751 - BUG/MINOR: cache/htx: Return only the headers of cached objects to HEAD requests
10752 - BUG/MINOR: mux-h1: Always initilize h1m variable in h1_process_input()
10753 - BUG/MEDIUM: proto_htx: Fix functions applying regex filters on HTX messages
10754 - BUG/MEDIUM: h2: advertise to servers that we don't support push
10755 - MINOR: standard: Add a function to parse uints (dotted notation).
10756 - MINOR: arg: Add support for ARGT_PBUF_FNUM arg type.
10757 - MINOR: http_fetch: add "req.ungrpc" sample fetch for gRPC.
10758 - MINOR: sample: Add two sample converters for protocol buffers.
10759 - DOC: sample: Add gRPC related documentation.
10760
Willy Tarreaufba74ea2018-12-22 11:19:45 +0100107612018/12/22 : 2.0-dev0
10762 - BUG/MAJOR: connections: Close the connection before freeing it.
10763 - REGTEST: Require the option LUA to run lua tests
10764 - REGTEST: script: Process script arguments before everything else
10765 - REGTEST: script: Evaluate the varnishtest command to allow quoted parameters
10766 - REGTEST: script: Add the option --clean to remove previous log direcotries
10767 - REGTEST: script: Add the option --debug to show logs on standard ouput
10768 - REGTEST: script: Add the option --keep-logs to keep all log directories
10769 - REGTEST: script: Add the option --use-htx to enable the HTX in regtests
10770 - REGTEST: script: Print only errors in the results report
10771 - REGTEST: Add option to use HTX prefixed by the macro 'no-htx'
10772 - REGTEST: Make reg-tests target support argument.
10773 - REGTEST: Fix a typo about barrier type.
10774 - REGTEST: Be less Linux specific with a syslog regex.
10775 - REGTEST: Missing enclosing quotes for ${tmpdir} macro.
10776 - REGTEST: Exclude freebsd target for some reg tests.
10777 - BUG/MEDIUM: h2: Don't forget to quit the sending_list if SUB_CALL_UNSUBSCRIBE.
10778 - BUG/MEDIUM: mux-h2: Don't forget to quit the send list on error reports
10779 - BUG/MEDIUM: dns: Don't prevent reading the last byte of the payload in dns_validate_response()
10780 - BUG/MEDIUM: dns: overflowed dns name start position causing invalid dns error
10781 - BUG/MINOR: compression/htx: Don't compress responses with unknown body length
10782 - BUG/MINOR: compression/htx: Don't add the last block of data if it is empty
10783 - MEDIUM: mux_h1: Implement h1_show_fd.
10784 - REGTEST: script: Add support of alternatives in requited options list
10785 - REGTEST: Add a basic test for the compression
10786 - BUG/MEDIUM: mux-h2: don't needlessly wake up the demux on short frames
10787 - REGTEST: A basic test for "http-buffer-request"
10788 - BUG/MEDIUM: server: Also copy "check-sni" for server templates.
10789 - MINOR: ssl: Add ssl_sock_set_alpn().
10790 - MEDIUM: checks: Add check-alpn.
10791 - wip
10792
Willy Tarreau82230502018-12-19 19:13:17 +0100107932018/12/19 : 1.9.0
10794 - BUG/MEDIUM: compression: Use the right buffer pointers to compress input data
10795 - BUG/MINOR: mux_pt: Set CS_FL_WANT_ROOM when count is zero in rcv_buf() callback
10796 - BUG/MEDIUM: connection: Add a new CS_FL_ERR_PENDING flag to conn_streams.
10797 - CONTRIB: debug: teach the "flags" utility about new conn_stream flags
10798 - BUG/MEDIUM: stream-int: always clear CS_FL_WANT_ROOM before receiving
10799 - BUG/MEDIUM: mux-h2: also restart demuxing when data are pending in demux
10800 - BUG/MEDIUM: mux-h2: restart demuxing as soon as demux data are available
10801 - BUG/MEDIUM: h2: fix aggregated cookie length computation in HTX mode
10802 - MINOR: mux-h2: report more h2c, last h2s and cs information on "show fd"
10803 - CONTRIB: debug: report stream-int's flag SI_FL_CLEAN_ABRT
10804 - MINOR: cli/stream: add the conn_stream in "show sess" output
10805 - BUG/MINOR: mux-h2: don't report a fantom h2s in "show fd"
10806 - BUG/MINOR: cli/fd: don't isolate the thread for each individual fd
10807 - MINOR: objtype: report a few missing types in names and base pointers
10808 - BUG/MEDIUM: mux-h2: make sure to report synchronous errors after EOS
10809 - BUG/MEDIUM: mux-h2: report asynchronous errors in h2_wake_some_streams()
10810 - BUG/MEDIUM: mux-h2: make sure the demux also wakes streams up on errors
10811 - BUG/MINOR: mux-h1: report the correct frontend in error captures
10812 - BUG/MEDIUM: stream-int: also wake the stream up on end of transfer
10813 - MEDIUM: h2: properly check and deduplicate the content-length header in HTX
10814 - BUG/MEDIUM: stream: Forward the right amount of data before infinite forwarding
10815 - BUG/MINOR: proto_htx: Call the HTX version of the function managing client cookies
10816 - BUG/MEDIUM: lua/htx: Handle EOM in receive/get_line calls in HTTP applets
10817 - BUG/MINOR: lua: Return an error if a legacy HTTP applet doesn't send anything
10818 - MINOR: compression: Remove the thread_local variable buf_output
10819 - CLEANUP: connection: rename subscription events values and event field
10820 - CLEANUP: connection: rename conn->mux_ctx to conn->ctx
10821 - MINOR: connection: remove an unwelcome dependency on struct stream
10822 - CLEANUP: stream-int: consistently call the si/stream_int functions
10823 - BUG/MEDIUM: h1: Don't shutw/shutr the connection if we have keepalive.
10824 - BUG/MEDIUM: H2: Make sure htx is set even on empty frames.
10825 - BUG/MEDIUM: mux-h2: pass CS_FL_ERR_PENDING to h2_wake_some_streams()
10826 - MEDIUM: stream-int: always consider all CS errors on the send side
10827 - BUG/MEDIUM: h2: Make sure we don't set CS_FL_ERROR if there's still data.
10828 - CLEANUP: mux-h2: implement h2s_notify_{send,recv} to report events to subscribers
10829 - MINOR: mux-h2: add a new function h2s_alert() to call the data layer
10830 - BUG/MEDIUM: mux-h2: make use of h2s_alert() to report aborts
10831 - MINOR: connection: add cs_set_error() to set the error bits
10832 - CLEANUP: mux-h2: make use of cs_set_error()
10833 - BUG/MINOR: mux-h2: make sure we check the conn_stream in early data
10834 - BUG/MEDIUM: h2: Don't wait for flow control if the connection had a shutr.
10835 - MINOR: cli/show_fd: report that a connection is back or not
10836 - SCRIPTS: add the slack channel URL to the announce script
10837 - CLEANUP: remove my name and address from the copyright banner
10838 - DOC: mention in the readme that 1.9 is a stable version now
10839
Willy Tarreau2a7d6502018-12-16 22:35:06 +0100108402018/12/16 : 1.9-dev11
10841 - BUG/MEDIUM: connection: Don't use the provided conn_stream if it was tried.
10842 - REGTEST/MINOR: remove double body specification for server txresp
10843 - BUG/MEDIUM: connections: Remove error flags when retrying.
10844 - REGTEST/MINOR: skip seamless-reload test with abns socket on freebsd
10845 - REGTEST/MINOR: remove health-check that can make the test fail
10846 - DOC: clarify that check-sni needs an argument.
10847 - DOC: refer to check-sni in the documentation of sni
10848 - BUG/MEDIUM: mux-h2: fix encoding of non-GET/POST methods
10849 - BUG/MINOR: mux-h1: Fix conn_mode processing for headerless outgoing messages
10850 - BUG/MEDIUM: mux-h1: Add a BUSY mode to not loop on pipelinned requests
10851 - BUG/MEDIUM: mux-h1: Don't loop on the headers parsing if the read0 was received
10852 - BUG/MEDIUM: htx: Always do a defrag if a block value is replace by a bigger one
10853 - BUG/MEDIUM: mux-h2: Don't forget to set the CS_FL_EOS flag with htx.
10854 - BUG/MINOR: hpack: fix off-by-one in header name encoding length calculation
10855 - CLEANUP: hpack: no need to include chunk.h, only include buf.h
10856 - MINOR: hpack: simplify the len to bytes conversion
10857 - MINOR: hpack: use ist2bin() to copy header names in hpack_encode_header()
10858 - MINOR: hpack: optimize header encoding for short names
10859 - CONTRIB: hpack: add a compressed stream generator for the encoder
10860 - MEDIUM: hpack: make it possible to encode any static header name
10861 - MINOR: hpack: move the length computation and encoding functions to .h
10862 - MINOR: hpack: provide a function to encode a short indexed header
10863 - MINOR: hpack: provide a function to encode a long indexed header
10864 - MINOR: hpack: provide new functions to encode the ":status" header
10865 - MEDIUM: mux-h2: make use of standard HPACK encoding functions for the status
10866 - MINOR: hpack: provide a function to encode an HTTP method
10867 - MEDIUM: mux-h2: make use of hpack_encode_method() to encode the method
10868 - MINOR: hpack: provide a function to encode an HTTP scheme
10869 - MEDIUM: mux-h2: make use of hpack_encode_scheme() to encode the scheme
10870 - MINOR: hpack: provide a function to encode an HTTP path
10871 - MEDIUM: mux-h2: make use of hpack_encode_path() to encode the path
10872 - REGTEST: add the HTTP rules test involving HTX processing
10873 - REORG: connection: centralize the conn_set_{tos,mark,quickack} functions
10874 - MEDIUM: cli: rework the CLI proxy parser
10875 - MINOR: cli: parse prompt command in the CLI proxy
10876 - MINOR: cli: implements 'quit' in the CLI proxy
10877 - BUG/MINOR: cli: wait for payload data even without prompt
10878 - MEDIUM: cli: handle payload in CLI proxy
10879 - MINOR: cli: use pcli_flags for prompt activation
10880 - MINOR: compression: Rename the function check_legacy_http_comp_flt()
10881 - MINOR: cache/htx: Don't use the same cache on HTX and legacy HTTP proxies
10882 - MINOR: cache: Register the cache as a data filter only if response is cacheable
10883 - MEDIUM: cache/htx: Add the HTX support into the cache
10884 - MINOR: cache: Improve and simplify the cache configuration check
10885 - MINOR: filters: Export the name of known filters
10886 - MEDIUM: cache/compression: Add a way to safely combined compression and cache
10887 - MEDIUM: cache: Require an explicit filter declaration if other filters are used
10888 - REORG: htx: merge types+proto into common/htx.h
10889 - REORG: http: create http_msg.c to place there some legacy HTTP parts
10890 - REORG: h1: move legacy http functions to http_msg.c
10891 - REORG: h1: move the h1_state definition to proto_http
10892 - CLEANUP: h1: remove some occurrences of unneeded h1.h inclusions
10893 - REORG: h1: merge types+proto into common/h1.h
10894 - CLEANUP: stream: remove SF_TUNNEL, SF_INITIALIZED, SF_CONN_TAR
10895 - MEDIUM: mux-h1: implement true zero-copy of DATA blocks
10896 - MINOR: config: round up global.tune.bufsize to the next multiple of 2 void*
10897 - BUG/MINOR: mux-h2: refrain from muxing during the preface
10898 - BUG/MINOR: mux-h2: advertise a larger connection window size
10899 - DOC: master CLI documentation in management.txt
10900 - MINOR: mux-h2: avoid copying large blocks into full buffers
10901 - MEDIUM: mux-h2: implement true zero-copy send of large HTX DATA blocks
10902 - MINOR: mux-h2: force reads to be HTX-aligned in HTX mode
10903 - MINOR: cli: change 'show proc' output of old processes
10904 - BUG/MEDIUM: mux-h1: Fix the zero-copy on output for chunked messages
10905 - BUG: dns: Prevent stack-exhaustion via recursion loop in dns_read_name
10906 - BUG: dns: Prevent out-of-bounds read in dns_read_name()
10907 - BUG: dns: Prevent out-of-bounds read in dns_validate_dns_response()
10908 - BUG: dns: Fix out-of-bounds read via signedness error in dns_validate_dns_response()
10909 - BUG: dns: Fix off-by-one write in dns_validate_dns_response()
10910 - REGTEST: the cache regtest requires haproxy 1.9
10911 - MEDIUM: cli: store CLI level in the appctx
10912 - MEDIUM: cli: show and change CLI permissions
10913 - CLEANUP: cli: use dedicated define instead of appctx ones
10914 - MEDIUM: cli: handle CLI level from the master CLI
10915 - BUG/MEDIUM: cli: handle correctly prefix and payload
10916 - BUILD: Makefile: Implements the help target
10917 - REGTESTS: adjust the http-rules regtest to support window updates
10918 - BUG/MEDIUM: connections: Remove CS_FL_EOS | CS_FL_REOS on retry.
10919 - BUG/MEDIUM: stream_interface: Don't report read0 if we were not connected.
10920 - BUG/MEDIUM: connection: Just make sure we closed the fd on connection failure.
10921 - MEDIUM: mux: Add an optional "reset" method.
10922 - BUG/MEDIUM: mux-h1: Fix loop if server closes its connection with unparsed data
10923 - MINOR: mux-h1: Add helper functions to wake a stream from recv or send
10924 - BUG/MEDIUM: mux-h1: Wake the stream for send once the connection is established
10925 - BUG/MEDIUM: connections: Don't attempt to reuse an unusable connection.
10926 - MEDIUM: htx: Try to take a connection over if it has no owner.
10927 - REGTEST: Reg testing improvements.
10928 - REGTEST: Add a first test for health-checks.
10929 - REGTEST: Reg test for "check" health-check option.
10930 - REGTEST: level 1 health-check test 2.
10931 - REGTEST: Add miscellaneous reg tests for health-checks.
10932 - REGTEST: add a few HTTP messaging tests
10933 - MINOR: lb: make the leastconn algorithm more accurate
10934 - REGTEST: fix missing space in checks/s00001
10935 - REGTEST: http-messaging: add "option http-buffer-request" for H2 tests
10936 - BUG/MEDIUM: cache: fix random crash on filter parser's error path
10937 - MINOR: connection: realign empty buffers in muxes, not transport layers
10938 - MINOR: mux_h1/h2: simplify the zero-copy Rx alignment
10939 - MINOR: backend: count the number of connect and reuse per server and per backend
10940 - BUG/MINOR: stats: fix inversion of failed header rewrites and other statuses
10941 - MINOR: tools: increase the number of ITOA strings to 16
10942 - MINOR: cache: report the number of cache lookups and cache hits
10943 - MEDIUM: tasks: check the global task mask instead of the thread number
10944 - MINOR: mworker: set all_threads_mask and pid_bit to 1
10945 - BUG/MINOR: proto_htx: Fix htx_res_set_status to also set the reason
10946 - BUG/MINOR: stats: Parse post data for HTX streams
10947 - MINOR: payload/htx: Adapt smp_fetch_len to be HTX aware
10948 - MINOR: http_fecth: Implement body_len and body_size sample fetches for the HTX
10949 - MAJOR: lua: Forbid calls to Channel functions for LUA scripts in HTTP proxies
10950 - MEDIUM: lua/htx: Adapt functions of the HTTP to be compatible with HTX
10951 - MINOR: lua/htx: Adapt the functions get_in_length and is_full to be HTX aware
10952 - MAJOR: lua/htx: Adapt HTTP applets to support HTX messages
10953 - MINOR: lua: Remove useless check on the messages state in HTTP functions
10954 - BUG/MEDIUM: htx: When performing zero-copy, start from the right offset.
10955 - BUG/MINOR: mworker: don't use unitialized mworker_proc struct
10956 - MINOR: mworker/cli: indicate in the master prompt when a reload failed
10957 - MINOR: cli: implements 'reload' on master CLI
10958 - BUG/MEDIUM: log: Don't call sample_fetch_as_type if we don't have a stream.
10959 - BUG/MEDIUM: mux-h1: make sure we always have at least one HTX block to send
10960 - BUG/MAJOR: backend: only update server's counters when the server exists
10961 - MINOR: tools: preset the port of fd-based "sockets" to zero
10962 - BUG/MINOR: log: fix logging to both FD and IP
10963 - REGTEST: Add a reg test for HTTP cookies.
10964 - BUILD: ssl: Fix compilation without deprecated OpenSSL 1.1 APIs
10965 - BUILD: thread: properly report multi-thread support
10966 - BUG/MINOR: logs: leave startup-logs global and not per-thread
10967 - BUG/MEDIUM: threads: don't close the thread waker pipe if not init
10968 - BUG/MAJOR: compression/cache: Make it really works with these both filters
10969 - BUG/MEDIUM: h2: Don't forget to destroy the h2s after deferred shut.
10970 - MEDIUM: proxy: Set http-reuse safe as default.
10971 - MEDIUM: servers: Add a command to limit the number of idling connections.
10972 - MEDIUM: servers: Replace idle-timeout with pool-purge-delay.
10973 - MEDIUM: mux: Destroy the stream before trying to add the conn to the idle list.
10974 - MEDIUM: mux: provide the session to the init() and attach() method.
10975 - MEDIUM: sessions: Don't keep an infinite number of idling connections.
10976 - MEDIUM: servers: Be more agressive when adding H2 connection to idle lists.
10977 - MEDIUM: mux_h2: Always set CS_FL_NOT_FIRST for new conn_streams.
10978 - BUG/MEDIUM: htx/cache: use the correct class of error codes on abort
10979 - BUG/MINOR: cache: also consider CF_SHUTR to abort delivery
10980 - MINOR: pools: Cast to volatile int * instead of int *.
10981 - MINOR: debug: make the ABORT_NOW macro use a volatile int
10982 - BUG/MEDIUM: h2: Don't destroy the h2s if it still has a cs attached.
10983 - BUG/MEDIUM: mux-h1: don't try to process an empty input buffer
10984 - DOC: clarify the agent-check status line syntax
10985 - BUG/MAJOR: hpack: fix length check for short names encoding
10986 - DOC: split the README into README + INSTALL
10987
Willy Tarreau72e92272018-12-08 16:20:55 +0100109882018/12/08 : 1.9-dev10
10989 - MINOR: htx: Rename functions htx_*_to_str() to be H1 specific
10990 - BUG/MINOR: htx: Force HTTP/1.1 on H1 formatting when version is 1.1 or above
10991 - BUG/MINOR: fix ssl_fc_alpn and actually add ssl_bc_alpn
10992 - BUG/MEDIUM: mworker: stop proxies which have no listener in the master
10993 - BUG/MEDIUM: h1: Destroy a connection after detach if it has no owner.
10994 - BUG/MEDIUM: h2: Don't forget to wake the tasklet after shutr/shutw.
10995 - BUG/MINOR: flt_trace/compression: Use the right flag to add the HTX support
10996 - BUG/MEDIUM: stream_interface: Make REALLY sure we read all the data.
10997 - MEDIUM: mux-h1: Revamp the way subscriptions are handled.
10998 - BUG/MEDIUM: mux-h1: Always set CS_FL_RCV_MORE when data are received in h1_recv()
10999 - MINOR: mux-h1: Make sure to return 1 in h1_recv() when needed
11000 - BUG/MEDIUM: mux-h1: Release the mux H1 in h1_process() if there is no h1s
11001 - BUG/MINOR: proto_htx: Truncate the request when an error is detected
11002 - BUG/MEDIUM: h2: When sending in HTX, make sure the caller knows we sent all.
11003 - BUG/MEDIUM: mux-h2: properly update the window size in HTX mode
11004 - BUG/MEDIUM: mux-h2: make sure to always report HTX EOM when consumed by headers
11005 - BUG/MEDIUM: mux-h2: stop sending HTX once the mux is blocked
11006 - BUG/MEDIUM: mux-h2: don't send more HTX data than requested
11007 - MINOR: mux-h2: stop on non-DATA and non-EOM HTX blocks
11008 - BUG/MEDIUM: h1: Correctly report used data with no len.
11009 - MEDIUM: h1: Realign the ibuf before calling rcv_buf if needed.
11010 - BUG/MEDIUM: mux_pt: Always set CS_FL_RCV_MORE.
11011 - MINOR: htx: make htx_from_buf() adjust the size only on new buffers
11012 - MINOR: htx: add buf_room_for_htx_data() to help optimize buffer transfers
11013 - MEDIUM: mux-h1: make use of buf_room_for_htx_data() instead of b_room()
11014 - MEDIUM: mux-h1: attempt to zero-copy Rx DATA transfers
11015 - MEDIUM: mux-h1: avoid a double copy on the Tx path whenever possible
11016 - BUG/MEDIUM: stream-int: don't mark as blocked an empty buffer on Rx
11017 - BUG/MINOR: mux-h1: Check h1m flags to set the server conn_mode on request path
11018 - MEDIUM: htx: Rework conversion from a buffer to an htx structure
11019 - MEDIUM: channel/htx: Add functions for forward HTX data
11020 - MINOR: mux-h1: Don't adjust anymore the amount of data sent in h1_snd_buf()
11021 - CLEANUP: htx: Fix indentation here and there in HTX files
11022 - MINOR: mux-h1: Allow partial data consumption during outgoing data processing
11023 - BUG/MEDIUM: mux-h2: use the correct offset for the HTX start line
11024 - BUG/MEDIUM: mux-h2: stop sending using HTX on errors
11025 - MINOR: mux-h1: Drain obuf if the output is closed after sending data
11026 - BUG/MEDIUM: mworker: stop every tasks in the master
11027 - BUG/MEDIUM: htx: Set the right start-line offset after a defrag
11028 - BUG/MEDIUM: stream: Don't dereference s->txn when it is not there yet.
11029 - BUG/MEDIUM: connections: Reuse an already attached conn_stream.
11030 - MINOR: stream-int: add a new blocking condition on the remote connection
11031 - BUG/MEDIUM: stream-int: don't attempt to receive if the connection is not established
11032 - BUG/MEDIUM: lua: block on remote connection establishment
11033 - BUG/MEDIUM: mworker: fix several typos in mworker_cleantasks()
11034 - SCRIPTS/REGTEST: merge grep+sed into sed in run-regtests
11035 - BUG/MEDIUM: connections: Split CS_FL_RCV_MORE into 2 flags.
11036 - BUG/MEDIUM: h1: Don't free the connection if it's an outgoing connection.
11037 - BUG/MEDIUM: h1: Set CS_FL_REOS if we had a read0.
11038 - BUG/MEDIUM: mux-h1: Be sure to have a conn_stream to set CS_FL_REOS in h1_recv
11039 - REGTEST: Move LUA reg test 4 to level 1.
11040 - MINOR: ist: add functions to copy/uppercase/lowercase into a buffer or string
11041 - MEDIUM: ist: always turn header names to lower case
11042 - MINOR: h2: don't turn HTX header names to lower case anymore
11043 - MEDIUM: ist: use local conversion arrays to case conversion
11044 - MINOR: htx: switch to case sensitive search of lower case header names
11045 - MINOR: mux-h1: Set CS_FL_EOS when read0 is detected and no data are pending
11046 - BUG/MINOR: stream-int: Process read0 even if no data was received in si_cs_recv
11047 - REGTEST: fix the Lua test file name in test lua/h00002 :-)
11048 - REGTEST: add a basic test for HTTP rules manipulating headers
11049 - BUG/MEDIUM: sample: Don't treat SMP_T_METH as SMP_T_STR.
11050 - MINOR: sample: add bc_http_major
11051 - BUG/MEDIUM: htx: fix typo in htx_replace_stline() making it fail all the time
11052 - REGTEST: make the HTTP rules test compatible with HTTP/2 as well
11053 - BUG/MEDIUM: h2: Don't try to chunk data when using HTX.
11054 - MINOR: compiler: add a new macro ALREADY_CHECKED()
11055 - BUILD: h2: mark the start line already checked to avoid warnings
11056 - BUG/MINOR: mux-h1: Remove the connection header when it is useless
11057
Willy Tarreauda7e3be2018-12-02 19:31:37 +0100110582018/12/02 : 1.9-dev9
11059 - BUILD/MINOR: ssl: fix build with non-alpn/non-npn libssl
11060 - BUG/MINOR: mworker: Do not attempt to close(2) fd -1
11061 - BUILD: compression: fix build error with DEFAULT_MAXZLIBMEM
11062 - MINOR: compression: always create the compression pool
11063 - BUG/MEDIUM: mworker: fix FD leak upon reload
11064 - BUILD: htx: fix fprintf format inconsistency on 32-bit platforms
11065 - BUILD: buffers: buf.h requires unistd to get ssize_t on libmusl
11066 - MINOR: initcall: introduce a way to register init functions to call at boot
11067 - MINOR: init: process all initcalls in order at boot time
11068 - MEDIUM: init: convert all trivial registration calls to initcalls
11069 - MINOR: thread: provide a set of lock initialisers
11070 - MINOR: threads: add new macros to declare self-initializing locks
11071 - MEDIUM: init: use self-initializing spinlocks and rwlocks
11072 - MINOR: initcall: apply initcall to all register_build_opts() calls
11073 - MINOR: initcall: use initcalls for most post_{check,deinit} and per_thread*
11074 - MINOR: initcall: use initcalls for section parsers
11075 - MINOR: memory: add a callback function to create a pool
11076 - MEDIUM: init: use initcall for all fixed size pool creations
11077 - MEDIUM: memory: use pool_destroy_all() to destroy all pools on deinit()
11078 - MEDIUM: initcall: use initcalls for a few initialization functions
11079 - MEDIUM: memory: make the pool cache an array and not a thread_local
11080 - MINOR: ssl: free ctx when libssl doesn't support NPN
11081 - BUG/MINOR: proto_htx: only mark connections private if NTLM is detected
11082 - MINOR: h2: make struct h2_ops static
11083 - BUG/MEDIUM: mworker: avoid leak of client socket
11084 - REORG: mworker: declare master variable in global.h
11085 - BUG/MEDIUM: listeners: CLOEXEC flag is not correctly set
11086 - CLEANUP: http: Fix typo in init_http's comment
11087 - BUILD: Makefile: Disable -Wcast-function-type if it exists.
11088 - BUG/MEDIUM: h2: Don't bogusly error if the previous stream was closed.
11089 - REGTEST/MINOR: script: add run-regtests.sh script
11090 - REGTEST: Add a basic test for the cache.
11091 - BUG/MEDIUM: mux_pt: Don't forget to unsubscribe() on attach.
11092 - BUG/MINOR: ssl: ssl_sock_parse_clienthello ignores session id
11093 - BUG/MEDIUM: connections: Wake the stream once the mux is chosen.
11094 - BUG/MEDIUM: connections: Don't forget to detach the connection from the SI.
11095 - BUG/MEDIUM: stream_interface: Don't check if the handshake is done.
11096 - BUG/MEDIUM: stream_interface: Make sure we read all the data available.
11097 - BUG/MEDIUM: h2: Call h2_process() if there's an error on the connection.
11098 - REGTEST: Fix several issues.
11099 - REGTEST: lua: check socket functionality from a lua-task
11100 - BUG/MEDIUM: session: Remove the session from the session_list in session_free.
11101 - BUG/MEDIUM: streams: Don't assume we have a CS in sess_update_st_con_tcp.
11102 - BUG/MEDIUM: connections: Don't assume we have a mux in connect_server().
11103 - BUG/MEDIUM: connections: Remove the connection from the idle list before destroy.
11104 - BUG/MEDIUM: session: properly clean the outgoing connection before freeing.
11105 - BUG/MEDIUM: mux_pt: Don't try to send if handshake is not done.
11106 - MEDIUM: connections: Put H2 connections in the idle list if http-reuse always.
11107 - MEDIUM: h2: Destroy a connection with no stream if it has no owner.
11108 - MAJOR: sessions: Store multiple outgoing connections in the session.
11109 - MEDIUM: session: Steal owner-less connections on end of transaction.
11110 - MEDIUM: server: Be smarter about deciding to reuse the last server.
11111 - BUG/MEDIUM: Special-case http_proxy when dealing with outgoing connections.
11112 - BUG/MINOR: cfgparse: Fix transition between 2 sections with the same name
11113 - BUG/MINOR: http: Use out buffer instead of trash to display error snapshot
11114 - BUG/MINOR: htx: Fix block size calculation when a start-line is added/replaced
11115 - BUG/MINOR: mux-h1: Fix processing of "Connection: " header on outgoing messages
11116 - BUG/MEDIUM: mux-h1: Reset the H1 parser when an outgoing message is processed
11117 - BUG/MINOR: proto_htx: Send outgoing data to client to start response processing
11118 - BUG/MINOR: htx: Stop a header or a start line lookup on the first EOH or EOM
11119 - BUG/MINOR: connection: report mux modes when HTX is supported
11120 - MINOR: htx: add a function to cut the beginning of a DATA block
11121 - MEDIUM: conn_stream: Add a way to get mux's info on a CS from the upper layer
11122 - MINOR: mux-h1: Implement get_cs_info() callback
11123 - MINOR: stream: Rely on CS's info if it exists and fallback on session's ones
11124 - MINOR: proto_htx: Use conn_stream's info to set t_idle duration when possible
11125 - MINOR: mux-h1: Don't rely on the stream anymore in h1_set_srv_conn_mode()
11126 - MINOR: mux-h1: Write last chunk and trailers if not found in the HTX message
11127 - MINOR: mux-h1: Be prepare to fail when EOM is added during trailers parsing
11128 - MINOR: mux-h1: Subscribe to send in h1_snd_buf() when not all data have been sent
11129 - MINOR: mux-h1: Consume channel's data in a loop in h1_snd_buf()
11130 - MEDIUM: mux-h1: Add keep-alive outgoing connections in connections list
11131 - MINOR: htx: Add function to add an HTX block just before another one
11132 - MINOR: htx: Add function to iterate on an HTX message using HTX blocks
11133 - MINOR: htx: Add a function to find the HTX block corresponding to a data offset
11134 - MINOR: stats: Don't add end-of-data marker and trailers in the HTX response
11135 - MEDIUM: htx: Change htx_sl to be a struct instead of an union
11136 - MINOR: htx: Add the start-line offset for the HTX message in the HTX structure
11137 - MEDIUM: htx: Don't rely on h1_sl anymore except during H1 header parsing
11138 - MINOR: proto-htx: Use the start-line flags to set the HTTP messsage ones
11139 - MINOR: htx: Add BODYLESS flags on the HTX start-line and the HTTP message
11140 - MINOR: proto_htx: Use full HTX messages to send 100-Continue responses
11141 - MINOR: proto_htx: Use full HTX messages to send 103-Early-Hints responses
11142 - MINOR: proto_htx: Use full HTX messages to send 401 and 407 responses
11143 - MINOR: proto_htx: Send valid HTX message when redir mode is enabled on a server
11144 - MINOR: proto_htx: Send valid HTX message to send 30x responses
11145 - MEDIUM: proto_htx: Convert all HTTP error messages into HTX
11146 - MINOR: mux-h1: Process conn_mode on the EOH when no connection header is found
11147 - MINOR: mux-h1: Change client conn_mode on an explicit close for the response
11148 - MINOR: mux-h1: Capture bad H1 messages
11149 - MAJOR: filters: Adapt filters API to be compatible with the HTX represenation
11150 - MEDIUM: proto_htx/filters: Add data filtering during the forwarding
11151 - MINOR: flt_trace: Adapt to be compatible with the HTX representation
11152 - MEDIUM: compression: Adapt to be compatible with the HTX representation
11153 - MINOR: h2: implement H2->HTX request header frame transcoding
11154 - MEDIUM: mux-h2: register mux for both HTTP and HTX modes
11155 - MEDIUM: mux-h2: make h2_rcv_buf() support HTX transfers
11156 - MEDIUM: mux-h2: make h2_snd_buf() HTX-aware
11157 - MEDIUM: mux-h2: add basic H2->HTX transcoding support for headers
11158 - MEDIUM: mux-h2: implement emission of H2 headers frames from HTX blocks
11159 - MEDIUM: mux-h2: implement the emission of DATA frames from HTX DATA blocks
11160 - MEDIUM: mux-h2: support passing H2 DATA frames to HTX blocks
11161 - BUG/MINOR: cfgparse: Fix the call to post parser of the last sections parsed
11162 - BUG/MEDIUM: mux-h2: don't lose the first response header in HTX mode
11163 - BUG/MEDIUM: mux-h2: remove the HTX EOM block on H2 response headers
11164 - MINOR: listener: the mux_proto entry in the bind_conf is const
11165 - MINOR: connection: create conn_get_best_mux_entry()
11166 - MINOR: server: the mux_proto entry in the server is const
11167 - MINOR: config: make sure to associate the proper mux to bind and servers
11168 - MINOR: hpack: add ":path" to the list of common header fields
11169 - MINOR: h2: add new functions to produce an HTX message from an H2 response
11170 - MINOR: mux-h2: mention that the mux is compatible with both sides
11171 - MINOR: mux-h2: implement an outgoing stream allocator : h2c_bck_stream_new()
11172 - MEDIUM: mux-h2: start to create the outgoing mux
11173 - MEDIUM: mux-h2: implement encoding of H2 request on the backend side
11174 - MEDIUM: mux-h2: make h2_frt_decode_headers() direction-agnostic
11175 - MEDIUM: mux-h2: make h2_process_demux() capable of processing responses as well
11176 - MEDIUM: mux-h2: Implement h2_attach().
11177 - MEDIUM: mux-h2: Don't bother flagging outgoing connections as TOOMANY.
11178 - REGTEST: Fix LEVEL 4 script 0 of "connection" module.
11179 - MINOR: connection: Fix a comment.
11180 - MINOR: mux: add a "max_streams" method.
11181 - MEDIUM: servers: Add a way to keep idle connections alive.
11182 - CLEANUP: fix typos in the htx subsystem
11183 - CLEANUP: Fix typo in the chunk headers file
11184 - CLEANUP: Fix typos in the h1 subsystem
11185 - CLEANUP: Fix typos in the h2 subsystem
11186 - CLEANUP: Fix a typo in the mini-clist header
11187 - CLEANUP: Fix a typo in the proto_htx subsystem
11188 - CLEANUP: Fix typos in the proto_tcp subsystem
11189 - CLEANUP: Fix a typo in the signal subsystem
11190 - CLEANUP: Fix a typo in the session subsystem
11191 - CLEANUP: Fix a typo in the queue subsystem
11192 - CLEANUP: Fix typos in the shctx subsystem
11193 - CLEANUP: Fix typos in the socket pair protocol subsystem
11194 - CLEANUP: Fix typos in the map management functions
11195 - CLEANUP: Fix typo in the fwrr subsystem
11196 - CLEANUP: Fix typos in the cli subsystem
11197 - CLEANUP: Fix typo in the 51d subsystem
11198 - CLEANUP: Fix a typo in the base64 subsystem
11199 - CLEANUP: Fix a typo in the connection subsystem
11200 - CLEANUP: Fix a typo in the protocol header file
11201 - CLEANUP: Fix a typo in the checks header file
11202 - CLEANUP: Fix typos in the file descriptor subsystem
11203 - CLEANUP: Fix a typo in the listener subsystem
11204 - BUG/MINOR: lb-map: fix unprotected update to server's score
11205 - BUILD: threads: fix minor build warnings when threads are disabled
11206
Willy Tarreau0b936ad2018-11-25 09:16:46 +0100112072018/11/25 : 1.9-dev8
11208 - REORG: config: extract the global section parser into cfgparse-global
11209 - REORG: config: extract the proxy parser into cfgparse-listen.c
11210 - BUILD: update the list of supported targets and compilers in makefile and readme
11211 - BUILD: reorder the objects in the makefile
11212 - BUILD: Makefile: make "V=1" show some of the commands that are executed
11213 - BUILD: Makefile: add the quiet mode to a few more targets
11214 - BUILD: Makefile: add "$(Q)" to clean, tags and cscope targets
11215 - BUILD: Makefile: switch to quiet mode by default for CC/LD/AR
11216 - MINOR: cli: format `show proc` to be more readable
11217 - MINOR: cli: displays uptime in `show proc`
11218 - MINOR: cli: show master information in 'show proc'
11219 - BUG/MEDIUM: hpack: fix encoding of "accept-ranges" field
11220 - MAJOR: mux-h1: Remove the rxbuf and decode HTTP messages in channel's buffer
11221 - BUG/MINOR: mux-h1: Enable keep-alive on server side
11222 - BUG/MEDIUM: mux-h1: Fix freeze when the kernel splicing is used
11223 - BUG/MEDIUM: mux-h1: Don't set the flag CS_FL_RCV_MORE when nothing was parsed
11224 - BUG/MINOR: stats/htx: Remove channel's output when the request is eaten
11225 - BUG/MINOR: proto_htx: Fix request/response synchronisation on error
11226 - MINOR: stream-int: Notify caller when an error is reported after a rcv_pipe()
11227 - MINOR: stream-int: Notify caller when an error is reported after a rcv_buf()
11228 - BUG/MINOR: stream-int: Don't call snd_buf() if there are still data in the pipe
11229 - MINOR: stream-int: remove useless checks on CS and conn flags in si_cs_send()
11230 - BUG/MINOR: config: Be aware of the HTX during the check of mux protocols
11231 - BUG/MINOR: mux-htx: Fix bad test on h1c flags in h1_recv_allowed()
11232 - MEDIUM: mworker: wait mode use standard init code path
11233 - MINOR: log: introduce ha_notice()
11234 - MINOR: mworker: use ha_notice to announce a new worker
11235 - BUG/MEDIUM: http_fetch: Make sure name is initialized before http_find_header.
11236 - MINOR: cli: add mworker_accept_wrapper to 'show fd'
11237 - MEDIUM: signal: signal_unregister() removes every handlers
11238 - BUG/MEDIUM: mworker: unregister the signals of main()
11239 - MINOR: cli: add a few missing includes in proto/cli.h
11240 - REORG: time/activity: move activity measurements to activity.{c,h}
11241 - MINOR: activity: report the average loop time in "show activity"
11242 - MINOR: activity: add configuration and CLI support for "profiling.tasks"
11243 - MEDIUM: tasks: collect per-task CPU time and latency
11244 - MINOR: sample: add cpu_calls, cpu_ns_avg, cpu_ns_tot, lat_ns_avg, lat_ns_tot
11245 - MINOR: cli/activity: rename the stolen CPU time fields to mention milliseconds
11246 - BUG/MINOR: cli: Fix memory leak
11247 - BUG/MINOR: mworker: fix FD leak and memory leak in error path
11248 - MINOR: poller: move the call of tv_update_date() back to the pollers
11249 - MINOR: polling: add an option to support busy polling
11250 - MINOR: server: Add "alpn" and "npn" keywords.
11251 - MEDIUM: connection: Don't bother reactivating polling after connection retry.
11252 - MAJOR: connections: Defer mux creation for outgoing connection if alpn is set.
11253 - MEDIUM: ssl: Add ssl_bc_alpn and ssl_bc_npn sample fetches.
11254 - MINOR: servers: Free [idle|safe|priv]_conns on exit.
11255 - REGTEST: add the option to test only a specific set of files
11256 - REGTEST: add a test for connections to a "dispatch" address
11257 - BUG/MEDIUM: connections: Don't reset the conn flags in *connect_server().
11258 - MINOR: server: Only defined conn_complete_server if USE_OPENSSL is set.
11259 - BUG/MEDIUM: servers: Don't check if we have a conn_stream too soon.
11260 - BUG/MEDIUM: sessions: Set sess->origin to NULL if the origin was destroyed.
11261 - MEDIUM: servers: Store the connection in the SI until we have a mux.
11262 - BUG/MEDIUM: h2: wake the processing task up after demuxing
11263 - BUG/MEDIUM: h2: restart demuxing after releasing buffer space
11264
Willy Tarreau5c0e41b2018-11-18 22:33:00 +0100112652018/11/18 : 1.9-dev7
11266 - BUILD: cache: fix a build warning regarding too large an integer for the age
11267 - CLEANUP: fix typos in the comments of the Makefile
11268 - CLEANUP: fix a typo in a comment for the contrib/halog subsystem
11269 - CLEANUP: fix typos in comments for the contrib/modsecurity subsystem
11270 - CLEANUP: fix typos in comments for contrib/spoa_example
11271 - CLEANUP: fix typos in comments for contrib/wireshark-dissectors
11272 - DOC: Fix typos in README and CONTRIBUTING
11273 - MINOR: log: slightly improve error message syntax on log failure
11274 - DOC: logs: the format directive was missing from the second log part
11275 - MINOR: log: report the number of dropped logs in the stats
11276 - MEDIUM: log: add support for logging to existing file descriptors
11277 - MEDIUM: log: support a new "short" format
11278 - MEDIUM: log: add a new "raw" format
11279 - BUG/MEDIUM: stream-int: change the way buffer room is requested by a stream-int
11280 - BUG/MEDIUM: stream-int: convert some co_data() checks to channel_is_empty()
11281 - MINOR: namespaces: don't build namespace.c if disabled
11282 - BUILD/MEDIUM: threads/affinity: DragonFly build fix
11283 - MINOR: http: Add new "early-hint" http-request action.
11284 - MINOR: http: Make new "early-hint" http-request action really be parsed.
11285 - MINOR: http: Implement "early-hint" http request rules.
11286 - MINOR: doc: Add information about "early-hint" http-request action.
11287 - DOC: early-hints: fix truncated line.
11288 - MINOR: mworker: only close std{in,out,err} in daemon mode
11289 - BUG/MEDIUM: log: don't CLOEXEC the inherited FDs
11290 - BUG/MEDIUM: Make sure stksess is properly aligned.
11291 - BUG/MEDIUM: stream-int: make failed splice_in always subscribe to recv
11292 - BUG/MEDIUM: stream-int: clear CO_FL_WAIT_ROOM after splicing data in
11293 - BUG/MINOR: stream-int: make sure not to go through the rcv_buf path after splice()
11294 - CONTRIB: debug: fix build related to conn_stream flags change
11295 - REGTEST: fix scripts 1 and 3 to accept development version
11296 - BUG/MINOR: http_fetch: Remove the version part when capturing the request uri
11297 - MINOR: http: Regroup return statements of http_req_get_intercept_rule at the end
11298 - MINOR: http: Regroup return statements of http_res_get_intercept_rule at the end
11299 - BUG/MINOR: http: Be sure to sent fully formed HTTP 103 responses
11300 - MEDIUM: jobs: support unstoppable jobs for soft stop
11301 - MEDIUM: listeners: support unstoppable listener
11302 - MEDIUM: cli: worker socketpair is unstoppable
11303 - BUG/MINOR: stream-int: set SI_FL_WANT_PUT in sess_establish()
11304 - MINOR: stream: move the conn_stream specific calls to the stream-int
11305 - BUG/MINOR: config: Copy default error messages when parsing of a backend starts
11306 - CLEANUP: h2: minimum documentation for recent API changes
11307 - MINOR: mux: implement a get_first_cs() method
11308 - MINOR: stream-int: make conn_si_send_proxy() use cs_get_first()
11309 - MINOR: stream-int: relax the forwarding rules in stream_int_notify()
11310 - MINOR: stream-int: expand the flags to 32-bit
11311 - MINOR: stream-int: rename SI_FL_WAIT_ROOM to SI_FL_RXBLK_ROOM
11312 - MINOR: stream-int: introduce new SI_FL_RXBLK flags
11313 - MINOR: stream-int: add new functions si_{rx,tx}_{blocked,endp_ready}()
11314 - MINOR: stream-int: replace SI_FL_WANT_PUT with !SI_FL_RX_WAIT_EP
11315 - MINOR: stream-int: use si_rx_blocked()/si_tx_blocked() to check readiness
11316 - MEDIUM: stream-int: use si_rx_buff_{rdy,blk} to report buffer readiness
11317 - MINOR: stream-int: replace si_{want,stop}_put() with si_rx_endp_{more,done}()
11318 - MEDIUM: stream-int: update the endp polling status only at the end of si_cs_recv()
11319 - MINOR: stream-int: make si_sync_recv() simply check ENDP before si_cs_recv()
11320 - MINOR: stream-int: automatically mark applets as ready if they block on the channel
11321 - MEDIUM: stream-int: fix the si_cant_put() calls used for end point readiness
11322 - MEDIUM: stream-int: fix the si_cant_put() calls used for buffer readiness
11323 - MEDIUM: stream-int: use si_rx_shut_blk() to indicate the SI is closed
11324 - MEDIUM: stream-int: unconditionally call si_chk_rcv() in update and notify
11325 - MEDIUM: stream-int: make use of si_rx_chan_{rdy,blk} to control the stream-int from the channel
11326 - MINOR: stream-int: replace si_cant_put() with si_rx_room_{blk,rdy}()
11327 - MEDIUM: connections: Wait until the connection is established to try to recv.
11328 - MEDIUM: mux: Teach the mux_pt how to deal with idle connections.
11329 - MINOR: mux: Add a new "avail_streams" method.
11330 - MINOR: mux: Add a destroy() method.
11331 - MINOR: sessions: Start to store the outgoing connection in sessions.
11332 - MAJOR: connections: Detach connections from streams.
11333 - MINOR: conn_stream: Add a flag to notify the mux it should flush its buffers
11334 - MINOR: htx: Add proto_htx.c file
11335 - MINOR: conn_stream: Add a flag to notify the mux it must respect the reserve
11336 - MINOR: http: Add standalone functions to parse a start-line or a header
11337 - MINOR: http: Call http_send_name_header with the stream instead of the txn
11338 - MINOR: conn_stream: Add a flag to notify the SI some data were received
11339 - MINOR: http: Add macros to check if a stream uses the HTX representation
11340 - MEDIUM: proto_htx: Add HTX analyzers and use it when the mux H1 is used
11341 - MEDIUM: mux-h1: Add dummy mux to handle HTTP/1.1 connections
11342 - MEDIUM: mux-h1: Add parsing of incoming and ougoing HTTP messages
11343 - MAJOR: mux-h1/proto_htx: Handle keep-alive connections in the mux
11344 - MEDIUM: mux-h1: Add support of the kernel TCP splicing to forward data
11345 - MEDIUM: htx: Add API to deal with the internal representation of HTTP messages
11346 - MINOR: http_htx: Add functions to manipulate HTX messages in http_htx.c
11347 - MINOR: proto_htx: Add some functions to handle HTX messages
11348 - MAJOR: mux-h1/proto_htx: Switch mux-h1 and HTX analyzers on the HTX representation
11349 - MINOR: http_htx: Add functions to replace part of the start-line
11350 - MINOR: http_htx: Add functions to retrieve a specific occurrence of a header
11351 - MINOR: proto_htx: Rewrite htx_apply_redirect_rule to handle HTX messages
11352 - MINOR: proto_htx: Add the internal function htx_del_hdr_value
11353 - MINOR: proto_htx: Add the internal function htx_fmt_res_line
11354 - MINOR: proto_htx: Add functions htx_transform_header and htx_transform_header_str
11355 - MINOR: proto_htx: Add functions htx_req_replace_stline and htx_res_set_status
11356 - MINOR: proto_htx: Add function to build and send HTTP 103 responses
11357 - MINOR: proto_htx: Add functions htx_req_get_intercept_rule and htx_res_get_intercept_rule
11358 - MINOR: proto_htx: Add functions to apply req* and rsp* rules on HTX messages
11359 - MINOR: proto_htx: Add functions to manage cookies on HTX messages
11360 - MINOR: proto_htx: Add functions to check the cacheability of HTX messages
11361 - MINOR: proto_htx: Add functions htx_send_name_header
11362 - MINOR: proto_htx: Add functions htx_perform_server_redirect
11363 - MINOR: proto_htx: Add functions to handle the stats applet
11364 - MEDIUM: proto_htx: Adapt htx_process_req_common to handle HTX messages
11365 - MEDIUM: proto_htx: Adapt htx_process_request to handle HTX messages
11366 - MINOR: proto_htx: Adapt htx_process_tarpit to handle HTX messages
11367 - MEDIUM: proto_htx: Adapt htx_wait_for_request_body to handle HTX messages
11368 - MEDIUM: proto_htx: Adapt htx_process_res_common to handle HTX messages
11369 - MINOR: http_fetch: Add smp_prefetch_htx
11370 - MEDIUM: http_fetch: Adapt all fetches to handle HTX messages
11371 - MEDIUM: mux-h1: Wait for connection establishment before consuming channel's data
11372 - MINOR: stats/htx: Adapt the stats applet to handle HTX messages
11373 - MINOR: stream: Don't reset sov value with HTX messages
11374 - MEDIUM: mux-h1: Handle errors and timeouts in the stream
11375 - MINOR: filters/htx: Forbid filters when the HTX is enabled on a proxy
11376 - MINOR: lua/htx: Forbid lua usage when the HTX is enabled on a proxy
11377 - CLEANUP: Fix some typos in the haproxy subsystem
11378 - CLEANUP: Fix typos in the dns subsystem
11379 - CLEANUP: Fix typos in the pattern subsystem
11380 - CLEANUP: fix 2 typos in the xxhash subsystem
11381 - CLEANUP: fix a few typos in the comments of the server subsystem
11382 - CLEANUP: fix a misspell in tests/filltab25.c
11383 - CLEANUP: fix a typo found in the stream subsystem
11384 - CLEANUP: fix typos in comments in ebtree
11385 - CLEANUP: fix typos in reg-tests
11386 - CLEANUP: fix typos in the comments of the vars subsystem
11387 - CLEANUP: fix typos in the hlua_fcn subsystem
11388 - CLEANUP: fix typos in the proto_http subsystem
11389 - CLEANUP: fix typos in the proxy subsystem
11390 - CLEANUP: fix typos in the ssl_sock subsystem
11391 - DOC: Fix typos in different subsections of the documentation
11392 - DOC: fix a few typos in the documentation
11393 - MINOR: Fix an error message thrown when we run out of memory
11394 - MINOR: Fix typos in error messages in the proxy subsystem
11395 - MINOR: fix typos in the examples files
11396 - CLEANUP: Fix a typo in the stats subsystem
11397 - CLEANUP: Fix typos in the acl subsystem
11398 - CLEANUP: Fix typos in the cache subsystem
11399 - CLEANUP: Fix typos in the cfgparse subsystem
11400 - CLEANUP: Fix typos in the filters subsystem
11401 - CLEANUP: Fix typos in the http subsystem
11402 - CLEANUP: Fix typos in the log subsystem
11403 - CLEANUP: Fix typos in the peers subsystem
11404 - CLEANUP: Fix typos in the regex subsystem
11405 - CLEANUP: Fix typos in the sample subsystem
11406 - CLEANUP: Fix typos in the spoe subsystem
11407 - CLEANUP: Fix typos in the standard subsystem
11408 - CLEANUP: Fix typos in the stick_table subsystem
11409 - CLEANUP: Fix typos in the task subsystem
11410 - MINOR: Fix typo in error message in the standard subsystem
11411 - CLEANUP: fix typos in the comments of hlua
11412 - MINOR: Fix typo in the error 500 output of hlua
11413 - MINOR: Fix a typo in a warning message in the spoe subsystem
11414
Willy Tarreau96079492018-11-11 10:43:39 +0100114152018/11/11 : 1.9-dev6
11416 - BUG/MEDIUM: tools: fix direction of my_ffsl()
11417 - BUG/MINOR: cli: forward the whole command on master CLI
11418 - BUG/MEDIUM: auth/threads: use of crypt() is not thread-safe
11419 - MINOR: compat: automatically detect support for crypt_r()
11420 - MEDIUM: auth/threads: make use of crypt_r() on systems supporting it
11421 - DOC: split the http-request actions in their own section
11422 - DOC: split the http-response actions in their own section
11423 - BUG/MAJOR: stream-int: don't call si_cs_recv() in stream_int_chk_rcv_conn()
11424 - BUG/MINOR: tasks: make sure wakeup events are properly reported to subscribers
11425 - MINOR: stats: report the number of active jobs and listeners in "show info"
11426 - MINOR: stats: report the number of active peers in "show info"
11427 - MINOR: stats: report the number of currently connected peers
11428 - MINOR: cli: show the number of reload in 'show proc'
11429 - MINOR: cli: can't connect to the target CLI
11430 - MEDIUM: mworker: does not create the CLI proxy when no listener
11431 - MINOR: mworker: displays more information when leaving
11432 - MEDIUM: mworker: exit with the incriminated exit code
11433 - MINOR: mworker: displays a message when a worker is forked
11434 - MEDIUM: mworker: leave when the master die
11435 - CLEANUP: stream-int: retro-document si_cs_io_cb()
11436 - BUG/MEDIUM: mworker: does not abort() in mworker_pipe_register()
11437 - BUG/MEDIUM: stream-int: don't wake up for nothing during SI_ST_CON
11438 - BUG/MEDIUM: cli: crash when trying to access a worker
11439 - DOC: restore note about "independant" typo
11440 - MEDIUM: stream: implement stream_buf_available()
11441 - MEDIUM: appctx: check for allocation attempts in buffer allocation callbacks
11442 - MINOR: stream-int: rename si_applet_{want|stop|cant}_{get|put}
11443 - MINOR: stream-int: add si_done_{get,put} to indicate that we won't do it anymore
11444 - MINOR: stream-int: use si_cant_put() instead of setting SI_FL_WAIT_ROOM
11445 - MINOR: stream-int: make use of si_done_{get,put}() in shut{w,r}
11446 - MINOR: stream-int: make it clear that si_ops cannot be null
11447 - MEDIUM: stream-int: temporarily make si_chk_rcv() take care of SI_FL_WAIT_ROOM
11448 - MINOR: stream-int: factor the SI_ST_EST state test into si_chk_rcv()
11449 - MEDIUM: stream-int: make SI_FL_WANT_PUT reflect CF_DONT_READ
11450 - MEDIUM: stream-int: always call si_chk_rcv() when we make room in the buffer
11451 - MEDIUM: stream-int: make si_chk_rcv() check that SI_FL_WAIT_ROOM is cleared
11452 - MINOR: stream-int: replace si_update() with si_update_both()
11453 - MEDIUM: stream-int: make stream_int_update() aware of the lower layers
11454 - CLEANUP: stream-int: remove the now unused si->update() function
11455 - MEDIUM: stream-int: Rely only on SI_FL_WAIT_ROOM to stop data receipt
11456 - MEDIUM: stream-int: Try to read data even if channel's buffer seems to be full
11457 - BUG/MINOR: config: better detect the presence of the h2 pattern in npn/alpn
11458
Willy Tarreaubddf2922018-10-28 20:39:31 +0100114592018/10/28 : 1.9-dev5
11460 - BUILD: Makefile: add the new ERR variable to force -Werror
11461 - MINOR: freq_ctr: add swrate_add_scaled() to work with large samples
11462 - MINOR: stream_interface: Avoid calling si_cs_send/recv if not needed.
11463 - CLEANUP: http: Remove the unused function http_find_header
11464 - MINOR: h1: Export some functions parsing the value of some HTTP headers
11465 - BUG/MEDIUM: stream-int: don't set SI_FL_WAIT_ROOM on CF_READ_DONTWAIT
11466 - MINOR: proxy: add a new option "http-use-htx"
11467 - BUG/MEDIUM: pools: fix the minimum allocation size
11468 - MINOR: shctx: Shared objects block by block allocation.
11469 - MINOR: cache: Larger HTTP objects caching.
11470 - MINOR: shctx: Add a maximum object size parameter.
11471 - MINOR: cache: Add "max-object-size" option.
11472 - DOC: Update about the cache support for big objects.
11473 - BUG/MINOR: cache: Crashes with "total-max-size" > 2047(MB).
11474 - BUG/MINOR: cache: Wrong usage of shctx_init().
11475 - BUG/MINOR: ssl: Wrong usage of shctx_init().
11476 - MINOR: cache: Avoid usage of atoi() when parsing "max-object-size".
11477 - MINOR: shctx: Change max. object size type to unsigned int.
11478 - DOC: cache: Missing information about "total-max-size" and "max-object-size"
11479 - CLEANUP: tools: fix misleading comment above function LIM2A
11480 - MEDIUM: channel: merge back flags CF_WRITE_PARTIAL and CF_WRITE_EVENT
11481 - BUG/MINOR: only mark connections private if NTLM is detected
11482 - BUG/MINOR: only auto-prefer last server if lb-alg is non-deterministic
11483 - MINOR: stream: don't prune variables if the list is empty
11484 - MINOR: stream-int: add si_alloc_ibuf() to ease input buffer allocation
11485 - MEDIUM: stream-int: replace channel_alloc_buffer() with si_alloc_ibuf() everywhere
11486 - MEDIUM: stream: always call si_cs_recv() after a failed buffer allocation
11487 - MEDIUM: stream: don't try to send first in process_stream()
11488 - MEDIUM: stream-int: make si_update() synchronize flag changes before the I/O
11489 - MEDIUM: stream-int: call si_cs_process() in stream_int_update_conn
11490 - MINOR: stream-int: don't needlessly call tasklet_wakeup() in stream_int_chk_snd_conn()
11491 - MINOR: stream-int: make stream_int_notify() not wake the tasklet up
11492 - MINOR: stream-int: don't needlessly call si_cs_send() in si_cs_process()
11493 - MINOR: mworker: number of reload in the life of a worker
11494 - MEDIUM: mworker: each worker socketpair is a CLI listener
11495 - REORG: mworker: move struct mworker_proc to global.h
11496 - MINOR: server: export new_server() function
11497 - MEDIUM: mworker: move proc_list gen before proxies startup
11498 - MEDIUM: mworker: add proc_list in global.h
11499 - MEDIUM: mworker: proxy for the master CLI
11500 - MEDIUM: mworker: create CLI listeners from argv[]
11501 - MEDIUM: cli: disable some keywords in the master
11502 - MEDIUM: mworker: find the server ptr using a CLI prefix
11503 - MEDIUM: cli: 'show proc' displays processus
11504 - MEDIUM: cli: implement 'mode cli' proxy analyzers
11505 - MINOR: cli: displays sockpair@ in "show cli sockets"
11506 - MEDIUM: cli: enable "show cli sockets" for the master
11507 - MINOR: cli: put @master @<relative pid> @!<pid> in the help
11508 - MEDIUM: listeners: set O_CLOEXEC on the accepted FDs
11509 - MEDIUM: mworker: stop the master proxy in the workers
11510 - MEDIUM: channel: reorder the channel analyzers for the cli
11511 - MEDIUM: cli: write a prompt for the CLI proxy of the master
11512 - MINOR: cli: helper to write an response message and close
11513 - MINOR: cache: Add "Age" header.
11514 - REGTEST: make the IP+port logging test more reliable
11515 - BUG/MINOR: memory: make the thread-local cache allocator set the debugging link
11516 - BUG/MAJOR: http: http_txn_get_path() may deference an inexisting buffer
11517 - BUG/MINOR: backend: assign the wait list after the error check
11518
Willy Tarreau01fbe742018-10-21 20:28:30 +0200115192018/10/21 : 1.9-dev4
11520 - BUILD: Allow configuration of pcre-config path
11521 - DOC: clarify force-private-cache is an option
11522 - BUG/MINOR: connection: avoid null pointer dereference in send-proxy-v2
11523 - REORG: http: move the code to different files
11524 - REORG: http: move HTTP rules parsing to http_rules.c
11525 - CLEANUP: http: remove some leftovers from recent cleanups
11526 - BUILD: Makefile: add a "make opts" target to simply show the build options
11527 - BUILD: Makefile: speed up compiler options detection
11528 - BUG/MINOR: backend: check that the mux installed properly
11529 - BUG/MEDIUM: h2: check that the connection is still valid at the end of init()
11530 - BUG/MEDIUM: h2: make h2_stream_new() return an error on memory allocation failure
11531 - REGTEST/MINOR: compatibility: use unix@ instead of abns@ sockets
11532 - MINOR: ssl: cleanup old openssl API call
11533 - MINOR: ssl: generate-certificates for BoringSSL
11534 - BUG/MEDIUM: buffers: Make sure we don't wrap in ci_insert_line2/b_rep_blk.
11535 - MEDIUM: ssl: add support for ciphersuites option for TLSv1.3
11536 - CLEANUP: haproxy: Remove unused variable
11537 - CLEANUP: h1: Fix debug warnings for h1 headers
11538 - CLEANUP: stick-tables: Remove unneeded double (()) around conditional clause
11539 - MEDIUM: task: perform a single tree lookup per run queue batch
11540 - BUG/MEDIUM: Cur/CumSslConns counters not threadsafe.
11541 - BUG/MINOR: threads: move declaration of capabilities to config.h
11542 - OPTIM: tools: optimize my_ffsl() for x86_64
11543 - BUG/MINOR: h2: null-deref
11544 - BUG/MINOR: checks: queues null-deref
11545 - MINOR: connections: Introduce an unsubscribe method.
11546 - MEDIUM: connections: Change struct wait_list to wait_event.
11547 - BUG/MEDIUM: h2: Make sure we're not in the send list on flow control.
11548 - BUG/MEDIUM: mworker: segfault receiving SIGUSR1 followed by SIGTERM.
11549 - BUG/MEDIUM: stream: Make sure to unsubscribe before si_release_endpoint.
11550 - MINOR: http: Move comment about some HTTP macros in the right header file
11551 - MINOR: stats: Add missing include
11552 - MINOR: http: Export some functions and do cleanup to prepare HTTP refactoring
11553 - MEDIUM: http: Ignore http-pretend-keepalive option on frontend
11554 - MEDIUM: http: Ignore http-tunnel option on backend
11555 - MINOR: http: Use same flag for httpclose and forceclose options
11556 - MINOR: h1: Add EOH marker during headers parsing
11557 - MINOR: conn-stream: Add CL_FL_NOT_FIRST flag
11558 - MINOR: h1: Change the union h1_sl to use indirect strings to store infos
11559 - MINOR: h1: Add the flag H1_MF_NO_PHDR to not add pseudo-headers during parsing
11560 - MINOR: log: make sess_log() support sess=NULL
11561 - MINOR: chunk: add chunk_cpy() and chunk_cat()
11562 - MEDIUM: h2: stop relying on H2_SS_IDLE / H2_SS_CLOSED
11563 - CLEANUP: h2: rename h2c_snd_settings() to h2c_send_settings()
11564 - MINOR: h2: don't try to send data before preface
11565 - MINOR: h2: unify the mux init function
11566 - MINOR: h2: retrieve the front proxy from the caller instead of the session
11567 - MINOR: h2: split h2c_stream_new() into h2s_new() + h2c_frt_stream_new()
11568 - MINOR: h2: add a new flag to quickly distinguish front vs back connection
11569 - BUG/MEDIUM: mworker: don't poll on LI_O_INHERITED listeners
11570 - BUG/MEDIUM: stream: don't crash on out-of-memory
11571 - BUILD: compiler: add a new statement "__unreachable()"
11572 - BUILD: lua: silence some compiler warnings about potential null derefs
11573 - BUILD: ssl: fix null-deref warning in ssl_fc_cipherlist_str sample fetch
11574 - BUILD: ssl: fix another null-deref warning in ssl_sock_switchctx_cbk()
11575 - BUILD: stick-table: make sure not to fail on task_new() during initialization
11576 - BUILD: peers: check allocation error during peers_init_sync()
11577 - MINOR: tools: add a new function atleast2() to test masks for more than 1 bit
11578 - MINOR: config: use atleast2() instead of my_popcountl() where relevant
11579 - MEDIUM: fd/threads: only grab the fd's lock if the FD has more than one thread
11580 - MAJOR: tasks: create per-thread wait queues
11581 - OPTIM: tasks: group all tree roots per cache line
11582 - DOC: Fix a few typos
11583 - MINOR: pools: allocate most memory pools from an array
11584 - MINOR: pools: split pool_free() in the lockfree variant
11585 - MEDIUM: pools: implement a thread-local cache for pool entries
11586 - BUG/MEDIUM: threads: fix thread_release() at the end of the rendez-vous point
11587 - Revert "BUILD: lua: silence some compiler warnings about potential null derefs"
11588 - BUILD: lua: silence some compiler warnings about potential null derefs (#2)
11589 - MINOR: lua: all functions calling lua_yieldk() may return
11590 - BUILD: lua: silence some compiler warnings after WILL_LJMP
11591 - BUILD: Makefile: silence an option conflict warning with clang
11592 - MINOR: server: Use memcpy() instead of strncpy().
11593 - CLEANUP: state-file: make the path concatenation code a bit more consistent
11594 - MINOR: build: Disable -Wstringop-overflow.
11595 - MINOR: cfgparse: Write 130 as 128 as 0x82 and 0x80.
11596 - MINOR: peers: use defines instead of enums to appease clang.
11597 - DOC: fix reference to map files in MAINTAINERS
11598 - MINOR: fd: centralize poll timeout computation in compute_poll_timeout()
11599 - MINOR: poller: move time and date computation out of the pollers
11600 - BUILD: memory: fix pointer declaration for atomic CAS
11601 - BUILD: Makefile: add USE_RT to pass -lrt for clock_gettime() and friends
11602 - MINOR: time: add now_mono_time() and now_cpu_time()
11603 - MEDIUM: time: measure the time stolen by other threads
11604 - BUILD: memory: fix free_list pointer declaration again for atomic CAS
11605 - BUILD: compiler: rename __unreachable() to my_unreachable()
11606 - BUG/MEDIUM: pools: Fix the usage of mmap()) with DEBUG_UAF.
11607 - BUILD: memory: fix free_list pointer declaration again for atomic CAS
11608 - BUG/MEDIUM: h2: Close connection if no stream is left an GOAWAY was sent.
11609 - BUG/MEDIUM: connections: Remove subscription if going in idle mode.
11610 - BUG/MEDIUM: stream: Make sure polling is right on retry.
11611 - MINOR: h2: Make sure to return 1 in h2_recv() when needed.
11612 - MEDIUM: connections: Don't directly mess with the polling from the upper layers.
11613 - MINOR: streams: Call tasklet_free() after si_release_endpoint().
11614 - MINOR: connection: Add a SUB_CALL_UNSUBSCRIBE event.
11615 - MINOR: h2: Don't run tasks that are waiting to send if mux in full.
11616 - MINOR: ebtree: save 8 bytes in struct eb32sc_node
11617
Willy Tarreau27010f02018-09-29 20:17:33 +0200116182018/09/29 : 1.9-dev3
11619 - BUG/MINOR: h1: don't consider the status for each header
11620 - MINOR: h1: report in the h1m struct if the HTTP version is 1.1 or above
11621 - MINOR: h1: parse the Connection header field
11622 - DOC: Fix typos in lua documentation
11623 - MINOR: h1: Add H1_MF_XFER_LEN flag
11624 - MINOR: http: add http_hdr_del() to remove a header from a list
11625 - MINOR: h1: add headers to the list after controls, not before
11626 - MEDIUM: h1: better handle transfer-encoding vs content-length
11627 - MEDIUM: h1: deduplicate the content-length header
11628 - BUG/MEDIUM: patterns: fix possible double free when reloading a pattern list
11629 - BUG/MEDIUM: h1: Really skip all updates when incomplete messages are parsed
11630 - CLEANUP/CONTRIB: hpack: remove some h1 build warnings
11631 - BUG/MINOR: tools: fix set_net_port() / set_host_port() on IPv4
11632 - BUG/MINOR: cli: make sure the "getsock" command is only called on connections
11633 - MINOR: stktable: provide an unchecked version of stktable_data_ptr()
11634 - MINOR: stream-int: make si_appctx() never fail
11635 - BUILD: ssl_sock: remove build warnings on potential null-derefs
11636 - BUILD: stats: remove build warnings on potential null-derefs
11637 - BUILD: stream: address null-deref build warnings at -Wextra
11638 - BUILD: http: address a couple of null-deref warnings at -Wextra
11639 - BUILD: log: silent build warnings due to unchecked __objt_{server,applet}
11640 - BUILD: dns: fix null-deref build warning at -Wextra
11641 - BUILD: checks: silence a null-deref build warning at -Wextra
11642 - BUILD: connection: silence a couple of null-deref build warnings at -Wextra
11643 - BUILD: backend: fix 3 build warnings related to null-deref at -Wextra
11644 - BUILD: sockpair: silence a build warning at -Wextra
11645 - BUILD: build with -Wextra and sort out certain warnings
11646 - BUG/CRITICAL: hpack: fix improper sign check on the header index value
11647 - BUG/MEDIUM: http: Don't parse chunked body if there is no input data
11648 - DOC: Update configuration doc about the maximum number of stick counters.
11649 - BUG/MEDIUM: process_stream: Don't use si_cs_io_cb() in process_stream().
11650 - MINOR: h2/stream_interface: Reintroduce te wake() method.
11651 - BUG/MEDIUM: h2: Wake the task instead of calling h2_recv()/h2_process().
11652 - BUG/MEDIUM: process_stream(): Don't wake the task if no new data was received.
11653 - MEDIUM: lua: Add stick table support for Lua.
11654
Willy Tarreau253006d2018-09-12 18:59:48 +0200116552018/09/12 : 1.9-dev2
11656 - BUG/MINOR: buffers: Fix b_slow_realign when a buffer is realign without output
11657 - BUG/MEDIUM: threads: fix the no-thread case after the change to the sync point
11658 - BUG/MEDIUM: servers: check the queues once enabling a server
11659 - BUG/MEDIUM: queue: prevent a backup server from draining the proxy's connections
11660 - MEDIUM: mux: Remove const on the buffer in mux->snd_buf()
11661 - CLEANUP: backend: Move mux install to call it at only one place
11662 - MINOR: conn_stream: add an tx buffer to the conn_stream
11663 - MINOR: conn_stream: add cs_send() as a default snd_buf() function
11664 - MINOR: backend: Try to find the best mux for outgoing connections
11665 - MEDIUM: backend: don't rely on mux_pt_ops in connect_server()
11666 - MINOR: mux: Add info about the supported side in alpn_mux_list structure
11667 - MINOR: mux: Unlink ALPN and multiplexers to rather speak of mux protocols
11668 - MINOR: mux: Print the list of existing mux protocols during HA startup
11669 - MEDIUM: checks: use the new rendez-vous point to spread check result
11670 - MEDIUM: haproxy: don't use sync_poll_loop() anymore in the main loop
11671 - MINOR: threads: remove the previous synchronization point
11672 - MAJOR: server: make server state changes synchronous again
11673 - CLEANUP: server: remove the update list and the update lock
11674 - BUG/MINOR: threads: Remove the unexisting lock label "UPDATED_SERVERS_LOCK"
11675 - BUG/MEDIUM: stream_int: Don't check CO_FL_SOCK_RD_SH flag to trigger cs receive
11676 - MINOR: mux: Change get_mux_proto to get an ist as parameter
11677 - MINOR: mux: Improve the message with the list of existing mux protocols
11678 - MINOR: mux/frontend: Add 'proto' keyword to force the mux protocol
11679 - MINOR: mux/server: Add 'proto' keyword to force the multiplexer's protocol
11680 - MEDIUM: mux: Use the mux protocol specified on bind/server lines
11681 - BUG/MEDIUM: connection/mux: take care of serverless proxies
11682 - MINOR: queue: make sure the pendconn is released before logging
11683 - MINOR: stream: rename {srv,prx}_queue_size to *_queue_pos
11684 - MINOR: queue: store the queue index in the stream when enqueuing
11685 - MINOR: queue: replace the linked list with a tree
11686 - MEDIUM: add set-priority-class and set-priority-offset
11687 - MEDIUM: queue: adjust position based on priority-class and priority-offset
11688 - DOC: update the roadmap about priority queues
11689 - BUG/MINOR: ssl: empty connections reported as errors.
11690 - MINOR: connections: Make rcv_buf mandatory and nuke cs_recv().
11691 - MINOR: connections: Move rxbuf from the conn_stream to the h2s.
11692 - MINOR: connections: Get rid of txbuf.
11693 - MINOR: tasks: Allow tasklet_wakeup() to wakeup a task.
11694 - MINOR: connections/mux: Add the wait reason(s) to wait_list.
11695 - MINOR: stream_interface: Don't use si_cs_send() as a task handler.
11696 - MINOR: stream_interface: Give stream_interface its own wait_list.
11697 - MINOR: mux_h2: Don't use h2_send() as a callback.
11698 - MINOR: checks: Add event_srv_chk_io().
11699 - BUG/MEDIUM: tasks: Don't insert in the global rqueue if nbthread == 1
11700 - BUG/MEDIUM: sessions: Don't use t->state.
11701 - BUG/MEDIUM: ssl: fix missing error loading a keytype cert from a bundle.
11702 - BUG/MEDIUM: ssl: loading dh param from certifile causes unpredictable error.
11703 - BUG/MINOR: map: fix map_regm with backref
11704 - DOC: dns: explain set server ... fqdn requires resolver
11705 - DOC: add documentation for prio_class and prio_offset sample fetches.
11706 - DOC: ssl: Use consistent naming for TLS protocols
11707 - DOC: update the layering design notes
11708 - MINOR: tasks: Don't special-case when nbthreads == 1
11709 - MINOR: fd cache: And the thread_mask with all_threads_mask.
11710 - BUG/MEDIUM: lua: socket timeouts are not applied
11711 - BUG/MINOR: lua: fix extra 500ms added to socket timeouts
11712 - BUG/MEDIUM: server: update our local state before propagating changes
11713 - BUG/MEDIUM: cli/threads: protect all "proxy" commands against concurrent updates
11714 - DOC: server/threads: document which functions need to be called with/without locks
11715 - BUG/MEDIUM: cli/threads: protect some server commands against concurrent operations
11716 - BUG/MEDIUM: streams: Don't forget to remove the si from the wait list.
11717 - BUG/MEDIUM: tasklets: Add the thread as active when waking a tasklet.
11718 - BUG/MEDIUM: stream-int: Check if the conn_stream exist in si_cs_io_cb.
11719 - BUG/MEDIUM: H2: Activate polling after successful h2_snd_buf().
11720 - BUG/MEDIUM: stream_interface: Call the wake callback after sending.
11721 - BUG/MAJOR: queue/threads: make pendconn_redistribute not lock the server
11722 - BUG/MEDIUM: connection: don't forget to always delete the list's head
11723 - BUG/MEDIUM: lb/threads: always properly lock LB algorithms on maintenance operations
11724 - BUG/MEDIUM: check/threads: do not involve the rendez-vous point for status updates
11725 - BUG/MINOR: chunks: do not store -1 into chunk_printf() in case of error
11726 - BUG/MEDIUM: http: don't store exp_replace() result in the trash's length
11727 - BUG/MEDIUM: http: don't store url_decode() result in the samples's length
11728 - BUG/MEDIUM: dns: don't store dns_build_query() result in the trash's length
11729 - BUG/MEDIUM: map: don't store exp_replace() result in the trash's length
11730 - BUG/MEDIUM: connection: don't store recv() result into trash.data
11731 - BUG/MEDIUM: cli/ssl: don't store base64dec() result in the trash's length
11732 - MINOR: chunk: remove impossible tests on negative chunk->data
11733 - MINOR: sample: remove impossible tests on negative smp->data.u.str.data
11734 - DOC: Fix spelling error in configuration doc
11735 - REGTEST/MINOR: Missing mandatory "ignore_unknown_macro".
11736 - REGTEST/MINOR: Add a new class of regression testing files.
11737 - BUG/MEDIUM: unix: provide a ->drain() function
11738 - MINOR: connection: make conn_sock_drain() work for all socket families
11739 - BUG/MINOR: lua: Bad HTTP client request duration.
11740 - REGEST/MINOR: Add reg testing files.
11741 - BUG/MEDIUM: mux_pt: dereference the connection with care in mux_pt_wake()
11742 - REGTEST/MINOR: Add a reg testing file for b406b87 commit.
11743 - BUG/MEDIUM: lua: reset lua transaction between http requests
11744 - MINOR: add be_conn_free sample fetch
11745 - MINOR: Add srv_conn_free sample fetch
11746 - BUG/MEDIUM: hlua: Make sure we drain the output buffer when done.
11747 - MINOR: checks: Call wake_srv_chk() when we can finally send data.
11748 - BUG/MEDIUM: stream_interface: try to call si_cs_send() earlier.
11749 - BUG/MAJOR: thread: lua: Wrong SSL context initialization.
11750 - REGTEST/MINOR: Add a reg testing file for 3e60b11.
11751 - BUG/MEDIUM: hlua: Don't call RESET_SAFE_LJMP if SET_SAFE_LJMP returns 0.
11752 - REGTEST/MINOR: lua: Add reg testing files for 70d318c.
11753 - BUG/MEDIUM: dns/server: fix incomatibility between SRV resolution and server state file
11754 - BUG/MEDIUM: ECC cert should work with TLS < v1.2 and openssl >= 1.1.1
11755 - MINOR: tools: make date2str_log() take some consts
11756 - MINOR: thread: implement HA_ATOMIC_XADD()
11757 - BUG/MINOR: stream: use atomic increments for the request counter
11758 - BUG/MEDIUM: session: fix reporting of handshake processing time in the logs
11759 - BUG/MEDIUM: h2: fix risk of memory leak on malformated wrapped frames
11760 - BUG/MAJOR: buffer: fix incorrect check in __b_putblk()
11761 - MINOR: log: move the log code to sess_build_logline() to add extra arguments
11762 - MINOR: log: make the backend fall back to the frontend when there's no stream
11763 - MINOR: log: make sess_build_logline() not dereference a NULL stream for txn
11764 - MINOR: log: don't unconditionally pick log info from s->logs
11765 - CLEANUP: log: make the low_level lf_{ip,port,text,text_len} functions take consts
11766 - MINOR: log: keep a copy of the backend connection early in sess_build_logline()
11767 - MINOR: log: do not dereference a null stream to access captures
11768 - MINOR: log: be sure not to dereference a null stream for a target
11769 - MINOR: log: don't check the stream-int's conn_retries if the stream is NULL
11770 - MINOR: log: use NULL for the unique_id if there is no stream
11771 - MINOR: log: keep a copy of s->flags early to avoid a dereference
11772 - MINOR: log: use zero as the request counter if there is no stream
11773 - MEDIUM: log: make sess_build_logline() support being called with no stream
11774 - MINOR: log: provide a function to emit a log for a session
11775 - MEDIUM: h2: produce some logs on early errors that prevent streams from being created
11776 - BUG/MINOR: h1: fix buffer shift after realignment
11777 - MINOR: connection: make the initialization more consistent
11778 - MINOR: connection: add new function conn_get_proxy()
11779 - MINOR: connection: add new function conn_is_back()
11780 - MINOR: log: One const should be enough.
11781 - BUG/MINOR: dns: check and link servers' resolvers right after config parsing
11782 - BUG/MINOR: http/threads: atomically increment the error snapshot ID
11783 - MINOR: snapshot: restart on the event ID and not the stream ID
11784 - MINOR: snapshot: split the error snapshots into common and proto-specific parts
11785 - MEDIUM: snapshot: start to reorder the HTTP snapshot output a little bit
11786 - MEDIUM: snapshot: implement a show() callback and use it for HTTP
11787 - MINOR: proxy: add a new generic proxy_capture_error()
11788 - MINOR: http: make the HTTP error capture rely on the generic proxy code
11789 - MINOR: http: remove the pointer to the error snapshot in http_capture_bad_message()
11790 - REORG: cli: move the "show errors" handler from http to proxy
11791 - BUG/MEDIUM: snapshot: take the proxy's lock while dumping errors
11792 - MEDIUM: snapshots: dynamically allocate the snapshots
11793 - MEDIUM: snapshot: merge the captured data after the descriptor
11794 - MEDIUM: mworker: remove register/unregister signal functions
11795 - MEDIUM: mworker: use the haproxy poll loop
11796 - BUG/MINOR: mworker: no need to stop peers for each proxy
11797 - MINOR: mworker: mworker_cleanlisteners() delete the listeners
11798 - MEDIUM: mworker: block SIGCHLD until the master is ready
11799 - MEDIUM: mworker: never block SIG{TERM,INT} during reload
11800 - MEDIUM: startup: unify signal init between daemon and mworker mode
11801 - MINOR: mworker: don't deinit the poller fd when in wait mode
11802 - MEDIUM: mworker: master wait mode use its own initialization
11803 - MEDIUM: mworker: replace the master pipe by socketpairs
11804 - MINOR: mworker: keep and clean the listeners
11805 - MEDIUM: threads: close the thread-waker pipe during deinit
11806 - MEDIUM: mworker: call per_thread deinit in mworker_reload()
11807 - REORG: http: move the HTTP semantics definitions to http.h/http.c
11808 - REORG: http: move http_get_path() to http.c
11809 - REORG: http: move error codes production and processing to http.c
11810 - REORG: http: move the log encoding tables to log.c
11811 - REORG: http: move some header value processing functions to http.c
11812 - BUG/MAJOR: kqueue: Don't reset the changes number by accident.
11813 - MEDIUM: protocol: use a custom AF_MAX to help protocol parser
11814 - MEDIUM: protocol: sockpair protocol
11815 - TESTS: add a python wrapper for sockpair@
11816 - BUG/MINOR: server: Crash when setting FQDN via CLI.
11817 - BUG/MINOR: h2: report asynchronous end of stream on closed connections
11818 - BUILD: fix build without thread
11819 - BUG/MEDIUM: tasks: Don't forget to decrement task_list_size in tasklet_free().
11820 - MEDIUM: connections: Don't reset the polling flags in conn_fd_handler().
11821 - MEDIUM: connections/mux: Add a recv and a send+recv wait list.
11822 - MEDIUM: connections: Get rid of the recv() method.
11823 - MINOR: h2: Let user of h2_recv() and h2_send() know xfer has been done.
11824 - MEDIUM: h2: always subscribe to receive if allowed.
11825 - MEDIUM: h2: Don't use a wake() method anymore.
11826 - MEDIUM: stream_interface: Make recv() subscribe when more data is needed.
11827 - MINOR: connections: Add a "handle" field to wait_list.
11828 - MEDIUM: mux_h2: Revamp the send path when blocking.
11829 - MEDIUM: stream_interfaces: Starts receiving from the upper layers.
11830 - MINOR: checks: Give checks their own wait_list.
11831 - MINOR: conn_streams: Remove wait_list from conn_streams.
11832 - REORG: h1: create a new h1m_state
11833 - MINOR: h1: add the restart offsets into struct h1m
11834 - MINOR: h1: remove the unused states from h1m_state
11835 - MINOR: h1: provide a distinct init() function for request and response
11836 - MINOR: h1: add a message flag to indicate that a message carries a response
11837 - MINOR: h2: make sure h1m->err_pos field is correct on chunk error
11838 - MINOR: h1: properly pre-initialize err_pos to -2
11839 - MINOR: mux_h2: replace the req,res h1 messages with a single h1 message
11840 - MINOR: h2: pre-initialize h1m->err_pos to -1 on the output path
11841 - MEDIUM: h1: consider err_pos before deciding to accept a header name or not
11842 - MEDIUM: h1: make the parser support a pointer to a start line
11843 - MEDIUM: h1: let the caller pass the initial parser's state
11844 - MINOR: h1: make the message parser support a null <hdr> argument
11845 - MEDIUM: h1: support partial message parsing
11846 - MEDIUM: h1: remove the useless H1_MSG_BODY state
11847 - MINOR: h2: store the HTTP status into the H2S, not the H1M
11848 - MINOR: h1: remove the HTTP status from the H1M struct
11849 - MEDIUM: h1: implement the request parser as well
11850 - MINOR: h1: add H1_MF_TOLOWER to decide when to turn header names to lower case
11851 - MINOR: connection: pass the proxy when creating a connection
11852 - BUG/MEDIUM: h2: Don't forget to empty the wait lists on destroy.
11853 - BUG/MEDIUM: h2: Don't forget to set recv_wait_list to NULL in h2_detach.
11854 - BUG/MAJOR: h2: reset the parser's state on mux buffer full
11855
Willy Tarreau65e94d12018-08-02 18:12:50 +0200118562018/08/02 : 1.9-dev1
11857 - BUG/MEDIUM: kqueue: Don't bother closing the kqueue after fork.
11858 - DOC: cache: update sections and fix some typos
11859 - BUILD/MINOR: deviceatlas: enable thread support
11860 - BUG/MEDIUM: tcp-check: Don't lock the server in tcpcheck_main
11861 - BUG/MEDIUM: ssl: don't allocate shctx several time
11862 - BUG/MEDIUM: cache: bad computation of the remaining size
11863 - BUILD: checks: don't include server.h
11864 - BUG/MEDIUM: stream: fix session leak on applet-initiated connections
11865 - BUILD/MINOR: haproxy : FreeBSD/cpu affinity needs pthread_np header
11866 - BUILD/MINOR: Makefile : enabling USE_CPU_AFFINITY
11867 - BUG/MINOR: ssl: CO_FL_EARLY_DATA removal is managed by stream
11868 - BUG/MEDIUM: threads/peers: decrement, not increment jobs on quitting
11869 - BUG/MEDIUM: h2: don't report an error after parsing a 100-continue response
11870 - BUG/MEDIUM: peers: fix some track counter rules dont register entries for sync.
11871 - BUG/MAJOR: thread/peers: fix deadlock on peers sync.
11872 - BUILD/MINOR: haproxy: compiling config cpu parsing handling when needed
11873 - MINOR: config: report when "monitor fail" rules are misplaced
11874 - BUG/MINOR: mworker: fix validity check for the pipe FDs
11875 - BUG/MINOR: mworker: detach from tty when in daemon mode
11876 - MINOR: threads: Fix pthread_setaffinity_np on FreeBSD.
11877 - BUG/MAJOR: thread: Be sure to request a sync between threads only once at a time
11878 - BUILD: Fix LDFLAGS vs. LIBS re linking order in various makefiles
11879 - BUG/MEDIUM: checks: Be sure we have a mux if we created a cs.
11880 - BUG/MINOR: hpack: fix debugging output of pseudo header names
11881 - BUG/MINOR: hpack: must reject huffman literals padded with more than 7 bits
11882 - BUG/MINOR: hpack: reject invalid header index
11883 - BUG/MINOR: hpack: dynamic table size updates are only allowed before headers
11884 - BUG/MAJOR: h2: correctly check the request length when building an H1 request
11885 - BUG/MINOR: h2: immediately close if receiving GOAWAY after the last stream
11886 - BUG/MINOR: h2: try to abort closed streams as soon as possible
11887 - BUG/MINOR: h2: ":path" must not be empty
11888 - BUG/MINOR: h2: fix a typo causing PING/ACK to be responded to
11889 - BUG/MINOR: h2: the TE header if present may only contain trailers
11890 - BUG/MEDIUM: h2: enforce the per-connection stream limit
11891 - BUG/MINOR: h2: do not accept SETTINGS_ENABLE_PUSH other than 0 or 1
11892 - BUG/MINOR: h2: reject incorrect stream dependencies on HEADERS frame
11893 - BUG/MINOR: h2: properly check PRIORITY frames
11894 - BUG/MINOR: h2: reject response pseudo-headers from requests
11895 - BUG/MEDIUM: h2: remove connection-specific headers from request
11896 - BUG/MEDIUM: h2: do not accept upper case letters in request header names
11897 - BUG/MINOR: h2: use the H2_F_DATA_* macros for DATA frames
11898 - BUG/MINOR: action: Don't check http capture rules when no id is defined
11899 - BUG/MAJOR: hpack: don't pretend large headers fit in empty table
11900 - BUG/MINOR: ssl: support tune.ssl.cachesize 0 again
11901 - BUG/MEDIUM: mworker: also close peers sockets in the master
11902 - BUG/MEDIUM: ssl engines: Fix async engines fds were not considered to fix fd limit automatically.
11903 - BUG/MEDIUM: checks: a down server going to maint remains definitely stucked on down state.
11904 - BUG/MEDIUM: peers: set NOLINGER on the outgoing stream interface
11905 - BUG/MEDIUM: h2: fix handling of end of stream again
11906 - MINOR: mworker: Update messages referencing exit-on-failure
11907 - MINOR: mworker: Improve wording in `void mworker_wait()`
11908 - CONTRIB: halog: Add help text for -s switch in halog program
11909 - BUG/MEDIUM: email-alert: don't set server check status from a email-alert task
11910 - BUG/MEDIUM: threads/vars: Fix deadlock in register_name
11911 - MINOR: systemd: remove comment about HAPROXY_STATS_SOCKET
11912 - DOC: notifications: add precisions about thread usage
11913 - BUG/MEDIUM: lua/notification: memory leak
11914 - MINOR: conn_stream: add new flag CS_FL_RCV_MORE to indicate pending data
11915 - BUG/MEDIUM: stream-int: always set SI_FL_WAIT_ROOM on CS_FL_RCV_MORE
11916 - BUG/MEDIUM: h2: automatically set CS_FL_RCV_MORE when the output buffer is full
11917 - BUG/MEDIUM: h2: enable recv polling whenever demuxing is possible
11918 - BUG/MEDIUM: h2: work around a connection API limitation
11919 - BUG/MEDIUM: h2: debug incoming traffic in h2_wake()
11920 - MINOR: h2: store the demux padding length in the h2c struct
11921 - BUG/MEDIUM: h2: support uploading partial DATA frames
11922 - MINOR: h2: don't demand that a DATA frame is complete before processing it
11923 - BUG/MEDIUM: h2: don't switch the state to HREM before end of DATA frame
11924 - BUG/MEDIUM: h2: don't close after the first DATA frame on tunnelled responses
11925 - BUG/MEDIUM: http: don't disable lingering on requests with tunnelled responses
11926 - BUG/MEDIUM: h2: fix stream limit enforcement
11927 - BUG/MINOR: stream-int: don't try to receive again after receiving an EOS
11928 - MINOR: sample: add len converter
11929 - BUG: MAJOR: lb_map: server map calculation broken
11930 - BUG: MINOR: http: don't check http-request capture id when len is provided
11931 - MINOR: sample: rename the "len" converter to "length"
11932 - BUG/MEDIUM: mworker: Set FD_CLOEXEC flag on log fd
11933 - DOC/MINOR: intro: typo, wording, formatting fixes
11934 - MINOR: netscaler: respect syntax
11935 - MINOR: netscaler: remove the use of cip_magic only used once
11936 - MINOR: netscaler: rename cip_len to clarify its uage
11937 - BUG/MEDIUM: netscaler: use the appropriate IPv6 header size
11938 - BUG/MAJOR: netscaler: address truncated CIP header detection
11939 - MINOR: netscaler: check in one-shot if buffer is large enough for IP and TCP header
11940 - MEDIUM: netscaler: do not analyze original IP packet size
11941 - MEDIUM: netscaler: add support for standard NetScaler CIP protocol
11942 - MINOR: spoe: add force-set-var option in spoe-agent configuration
11943 - CONTRIB: iprange: Fix compiler warning in iprange.c
11944 - CONTRIB: halog: Fix compiler warnings in halog.c
11945 - BUG/MINOR: h2: properly report a stream error on RST_STREAM
11946 - MINOR: mux: add flags to describe a mux's capabilities
11947 - MINOR: stream-int: set flag SI_FL_CLEAN_ABRT when mux supports clean aborts
11948 - BUG/MEDIUM: stream: don't consider abortonclose on muxes which close cleanly
11949 - BUG/MEDIUM: checks: a server passed in maint state was not forced down.
11950 - BUG/MEDIUM: lua: fix crash when using bogus mode in register_service()
11951 - MINOR: http: adjust the list of supposedly cacheable methods
11952 - MINOR: http: update the list of cacheable status codes as per RFC7231
11953 - MINOR: http: start to compute the transaction's cacheability from the request
11954 - BUG/MINOR: http: do not ignore cache-control: public
11955 - BUG/MINOR: http: properly detect max-age=0 and s-maxage=0 in responses
11956 - BUG/MINOR: cache: do not force the TX_CACHEABLE flag before checking cacheability
11957 - MINOR: http: add a function to check request's cache-control header field
11958 - BUG/MEDIUM: cache: do not try to retrieve host-less requests from the cache
11959 - BUG/MEDIUM: cache: replace old object on store
11960 - BUG/MEDIUM: cache: respect the request cache-control header
11961 - BUG/MEDIUM: cache: don't cache the response on no-cache="set-cookie"
11962 - BUG/MAJOR: connection: refine the situations where we don't send shutw()
11963 - BUG/MEDIUM: checks: properly set servers to stopping state on 404
11964 - BUG/MEDIUM: h2: properly handle and report some stream errors
11965 - BUG/MEDIUM: h2: improve handling of frames received on closed streams
11966 - DOC/MINOR: configuration: typo, formatting fixes
11967 - BUG/MEDIUM: h2: ensure we always know the stream before sending a reset
11968 - BUG/MEDIUM: mworker: don't close stdio several time
11969 - MINOR: don't close stdio anymore
11970 - BUG/MEDIUM: http: don't automatically forward request close
11971 - BUG/MAJOR: hpack: don't return direct references to the dynamic headers table
11972 - MINOR: h2: add a function to report pseudo-header names
11973 - DEBUG: hpack: make hpack_dht_dump() expose the output file
11974 - DEBUG: hpack: add more traces to the hpack decoder
11975 - CONTRIB: hpack: add an hpack decoder
11976 - MEDIUM: h2: prepare a graceful shutdown when the frontend is stopped
11977 - BUG/MEDIUM: h2: properly handle the END_STREAM flag on empty DATA frames
11978 - BUILD: ssl: silence a warning when building without NPN nor ALPN support
11979 - CLEANUP: rbtree: remove
11980 - BUG/MEDIUM: ssl: cache doesn't release shctx blocks
11981 - BUG/MINOR: lua: Fix default value for pattern in Socket.receive
11982 - DOC: lua: Fix typos in comments of hlua_socket_receive
11983 - BUG/MEDIUM: lua: Fix IPv6 with separate port support for Socket.connect
11984 - BUG/MINOR: lua: Fix return value of Socket.settimeout
11985 - MINOR: dns: Handle SRV record weight correctly.
11986 - BUG/MEDIUM: mworker: execvp failure depending on argv[0]
11987 - MINOR: hathreads: add support for gcc < 4.7
11988 - BUILD/MINOR: ancient gcc versions atomic fix
11989 - BUG/MEDIUM: stream: properly handle client aborts during redispatch
11990 - MINOR: spoe: add register-var-names directive in spoe-agent configuration
11991 - MINOR: spoe: Don't queue a SPOE context if nothing is sent
11992 - DOC: clarify the scope of ssl_fc_is_resumed
11993 - CONTRIB: debug: fix a few flags definitions
11994 - BUG/MINOR: poll: too large size allocation for FD events
11995 - MINOR: sample: add date_us sample
11996 - BUG/MEDIUM: peers: fix expire date wasn't updated if entry is modified remotely.
11997 - MINOR: servers: Don't report duplicate dyncookies for disabled servers.
11998 - MINOR: global/threads: move cpu_map at the end of the global struct
11999 - MINOR: threads: add a MAX_THREADS define instead of LONGBITS
12000 - MINOR: global: add some global activity counters to help debugging
12001 - MINOR: threads/fd: Use a bitfield to know if there are FDs for a thread in the FD cache
12002 - BUG/MEDIUM: threads/polling: Use fd_cache_mask instead of fd_cache_num
12003 - BUG/MEDIUM: fd: maintain a per-thread update mask
12004 - MINOR: fd: add a bitmask to indicate that an FD is known by the poller
12005 - BUG/MEDIUM: epoll/threads: use one epoll_fd per thread
12006 - BUG/MEDIUM: kqueue/threads: use one kqueue_fd per thread
12007 - BUG/MEDIUM: threads/mworker: fix a race on startup
12008 - BUG/MINOR: mworker: only write to pidfile if it exists
12009 - MINOR: threads: Fix build when we're not compiling with threads.
12010 - BUG/MINOR: threads: always set an owner to the thread_sync pipe
12011 - BUG/MEDIUM: threads/server: Fix deadlock in srv_set_stopping/srv_set_admin_flag
12012 - BUG/MEDIUM: checks: Don't try to release undefined conn_stream when a check is freed
12013 - BUG/MINOR: kqueue/threads: Don't forget to close kqueue_fd[tid] on each thread
12014 - MINOR: threads: Use __decl_hathreads instead of #ifdef/#endif
12015 - BUILD: epoll/threads: Add test on MAX_THREADS to avoid warnings when complied without threads
12016 - BUILD: kqueue/threads: Add test on MAX_THREADS to avoid warnings when complied without threads
12017 - CLEANUP: sample: Fix comment encoding of sample.c
12018 - CLEANUP: sample: Fix outdated comment about sample casts functions
12019 - BUG/MINOR: sample: Fix output type of c_ipv62ip
12020 - CLEANUP: Fix typo in ARGT_MSK6 comment
12021 - CLEANUP: standard: Use len2mask4 in str2mask
12022 - MINOR: standard: Add str2mask6 function
12023 - MINOR: config: Add support for ARGT_MSK6
12024 - MEDIUM: sample: Add IPv6 support to the ipmask converter
12025 - MINOR: config: Enable tracking of up to MAX_SESS_STKCTR stick counters.
12026 - BUG/MINOR: cli: use global.maxsock and not maxfd to list all FDs
12027 - MINOR: polling: make epoll and kqueue not depend on maxfd anymore
12028 - MINOR: fd: don't report maxfd in alert messages
12029 - MEDIUM: polling: start to move maxfd computation to the pollers
12030 - CLEANUP: fd/threads: remove the now unused fdtab_lock
12031 - MINOR: poll: more accurately compute the new maxfd in the loop
12032 - CLEANUP: fd: remove the unused "new" field
12033 - MINOR: fd: move the hap_fd_{clr,set,isset} functions to fd.h
12034 - MEDIUM: select: make use of hap_fd_* functions
12035 - MEDIUM: fd: use atomic ops for hap_fd_{clr,set} and remove poll_lock
12036 - MEDIUM: select: don't use the old FD state anymore
12037 - MEDIUM: poll: don't use the old FD state anymore
12038 - MINOR: fd: pass the iocb and owner to fd_insert()
12039 - BUG/MINOR: threads: Update labels array because of changes in lock_label enum
12040 - MINOR: stick-tables: Adds support for new "gpc1" and "gpc1_rate" counters.
12041 - BUG/MINOR: epoll/threads: only call epoll_ctl(DEL) on polled FDs
12042 - DOC: don't suggest using http-server-close
12043 - MINOR: introduce proxy-v2-options for send-proxy-v2
12044 - BUG/MEDIUM: spoe: Always try to receive or send the frame to detect shutdowns
12045 - BUG/MEDIUM: spoe: Allow producer to read and to forward shutdown on request side
12046 - MINOR: spoe: Remove check on min_applets number when a SPOE context is queued
12047 - MINOR: spoe: Always link a SPOE context with the applet processing it
12048 - MINOR: spoe: Replace sending_rate by a frequency counter
12049 - MINOR: spoe: Count the number of frames waiting for an ack for each applet
12050 - MEDIUM: spoe: Use an ebtree to manage idle applets
12051 - MINOR: spoa_example: Count the number of frames processed by each worker
12052 - MINOR: spoe: Add max-waiting-frames directive in spoe-agent configuration
12053 - MINOR: init: make stdout unbuffered
12054 - MINOR: early data: Don't rely on CO_FL_EARLY_DATA to wake up streams.
12055 - MINOR: early data: Never remove the CO_FL_EARLY_DATA flag.
12056 - MINOR: compiler: introduce offsetoff().
12057 - MINOR: threads: Introduce double-width CAS on x86_64 and arm.
12058 - MINOR: threads: add test and set/reset operations
12059 - MINOR: pools/threads: Implement lockless memory pools.
12060 - MAJOR: fd/threads: Make the fdcache mostly lockless.
12061 - MEDIUM: fd/threads: Make sure we don't miss a fd cache entry.
12062 - MAJOR: fd: compute the new fd polling state out of the fd lock
12063 - MINOR: epoll: get rid of the now useless fd_compute_new_polled_status()
12064 - MINOR: kqueue: get rid of the now useless fd_compute_new_polled_status()
12065 - MINOR: poll: get rid of the now useless fd_compute_new_polled_status()
12066 - MINOR: select: get rid of the now useless fd_compute_new_polled_status()
12067 - CLEANUP: fd: remove the now unused fd_compute_new_polled_status() function
12068 - MEDIUM: fd: make updt_fd_polling() use atomics
12069 - MEDIUM: poller: use atomic ops to update the fdtab mask
12070 - MINOR: fd: move the fd_{add_to,rm_from}_fdlist functions to fd.c
12071 - BUG/MINOR: fd/threads: properly dereference fdcache as volatile
12072 - MINOR: fd: remove the unneeded last CAS when adding an fd to the list
12073 - MINOR: fd: reorder fd_add_to_fd_list()
12074 - BUG/MINOR: time/threads: ensure the adjusted time is always correct
12075 - BUG/MEDIUM: standard: Fix memory leak in str2ip2()
12076 - MINOR: init: emit warning when -sf/-sd cannot parse argument
12077 - BUILD: fd/threads: fix breakage build breakage without threads
12078 - DOC: Describe routing impact of using interface keyword on bind lines
12079 - DOC: Mention -Ws in the list of available options
12080 - BUG/MINOR: config: don't emit a warning when global stats is incompletely configured
12081 - BUG/MINOR: fd/threads: properly lock the FD before adding it to the fd cache.
12082 - BUG/MEDIUM: threads: fix the double CAS implementation for ARMv7
12083 - BUG/MEDIUM: ssl: Don't always treat SSL_ERROR_SYSCALL as unrecovarable.
12084 - BUILD/MINOR: memory: stdint is needed for uintptr_t
12085 - BUG/MINOR: init: Add missing brackets in the code parsing -sf/-st
12086 - DOC: lua: new prototype for function "register_action()"
12087 - DOC: cfgparse: Warn on option (tcp|http)log in backend
12088 - BUG/MINOR: ssl/threads: Make management of the TLS ticket keys files thread-safe
12089 - MINOR: sample: add a new "concat" converter
12090 - BUG/MEDIUM: ssl: Shutdown the connection for reading on SSL_ERROR_SYSCALL
12091 - BUG/MEDIUM: http: Switch the HTTP response in tunnel mode as earlier as possible
12092 - BUG/MEDIUM: ssl/sample: ssl_bc_* fetch keywords are broken.
12093 - MINOR: ssl/sample: adds ssl_bc_is_resumed fetch keyword.
12094 - CLEANUP: cfgparse: Remove unused label end
12095 - CLEANUP: spoe: Remove unused label retry
12096 - CLEANUP: h2: Remove unused labels from mux_h2.c
12097 - CLEANUP: pools: Remove unused end label in memory.h
12098 - CLEANUP: standard: Fix typo in IPv6 mask example
12099 - BUG/MINOR: pools/threads: don't ignore DEBUG_UAF on double-word CAS capable archs
12100 - BUG/MINOR: debug/pools: properly handle out-of-memory when building with DEBUG_UAF
12101 - MINOR: debug/pools: make DEBUG_UAF also detect underflows
12102 - MINOR: stats: display the number of threads in the statistics.
12103 - BUG/MINOR: h2: Set the target of dbuf_wait to h2c
12104 - BUG/MEDIUM: h2: always consume any trailing data after end of output buffers
12105 - BUG/MEDIUM: buffer: Fix the wrapping case in bo_putblk
12106 - BUG/MEDIUM: buffer: Fix the wrapping case in bi_putblk
12107 - BUG/MEDIUM: spoe: Remove idle applets from idle list when HAProxy is stopping
12108 - Revert "BUG/MINOR: send-proxy-v2: string size must include ('\0')"
12109 - MINOR: ssl: extract full pkey info in load_certificate
12110 - MINOR: ssl: add ssl_sock_get_pkey_algo function
12111 - MINOR: ssl: add ssl_sock_get_cert_sig function
12112 - MINOR: connection: add proxy-v2-options ssl-cipher,cert-sig,cert-key
12113 - MINOR: connection: add proxy-v2-options authority
12114 - MINOR: systemd: Add section for SystemD sandboxing to unit file
12115 - MINOR: systemd: Add SystemD's Protect*= options to the unit file
12116 - MINOR: systemd: Add SystemD's SystemCallFilter option to the unit file
12117 - CLEANUP: h2: rename misleading h2c_stream_close() to h2s_close()
12118 - MINOR: h2: provide and use h2s_detach() and h2s_free()
12119 - MEDIUM: h2: use a single buffer allocator
12120 - MINOR/BUILD: fix Lua build on Mac OS X
12121 - BUILD/MINOR: fix Lua build on Mac OS X (again)
12122 - BUG/MINOR: session: Fix tcp-request session failure if handshake.
12123 - CLEANUP: .gitignore: Ignore binaries from the contrib directory
12124 - BUG/MINOR: unix: Don't mess up when removing the socket from the xfer_sock_list.
12125 - DOC: buffers: clarify the purpose of the <from> pointer in offer_buffers()
12126 - BUG/MEDIUM: h2: also arm the h2 timeout when sending
12127 - BUG/MINOR: cli: Fix a crash when passing a negative or too large value to "show fd"
12128 - CLEANUP: ssl: Remove a duplicated #include
12129 - CLEANUP: cli: Remove a leftover debug message
12130 - BUG/MINOR: cli: Fix a typo in the 'set rate-limit' usage
12131 - BUG/MEDIUM: fix a 100% cpu usage with cpu-map and nbthread/nbproc
12132 - BUG/MINOR: force-persist and ignore-persist only apply to backends
12133 - BUG/MEDIUM: threads/unix: Fix a deadlock when a listener is temporarily disabled
12134 - BUG/MAJOR: threads/queue: Fix thread-safety issues on the queues management
12135 - BUG/MINOR: dns: don't downgrade DNS accepted payload size automatically
12136 - TESTS: Add a testcase for multi-port + multi-server listener issue
12137 - CLEANUP: dns: remove duplicate code in src/dns.c
12138 - BUG/MINOR: seemless reload: Fix crash when an interface is specified.
12139 - BUG/MINOR: cli: Ensure all command outputs end with a LF
12140 - BUG/MINOR: cli: Fix a crash when sending a command with too many arguments
12141 - BUILD: ssl: Fix build with OpenSSL without NPN capability
12142 - BUG/MINOR: spoa-example: unexpected behavior for more than 127 args
12143 - BUG/MINOR: lua: return bad error messages
12144 - CLEANUP: lua/syntax: lua is a name and not an acronym
12145 - BUG/MEDIUM: tcp-check: single connect rule can't detect DOWN servers
12146 - BUG/MINOR: tcp-check: use the server's service port as a fallback
12147 - BUG/MEDIUM: threads/queue: wake up other threads upon dequeue
12148 - MINOR: log: stop emitting alerts when it's not possible to write on the socket
12149 - BUILD/BUG: enable -fno-strict-overflow by default
12150 - BUG/MEDIUM: fd/threads: ensure the fdcache_mask always reflects the cache contents
12151 - DOC: log: more than 2 log servers are allowed
12152 - MINOR: hash: add new function hash_crc32c
12153 - MINOR: proxy-v2-options: add crc32c
12154 - MINOR: accept-proxy: support proxy protocol v2 CRC32c checksum
12155 - REORG: compact "struct server"
12156 - MINOR: samples: add crc32c converter
12157 - BUG/MEDIUM: h2: properly account for DATA padding in flow control
12158 - BUG/MINOR: h2: ensure we can never send an RST_STREAM in response to an RST_STREAM
12159 - BUG/MINOR: listener: Don't decrease actconn twice when a new session is rejected
12160 - CLEANUP: map, stream: remove duplicate code in src/map.c, src/stream.c
12161 - BUG/MINOR: lua: the function returns anything
12162 - BUG/MINOR: lua funtion hlua_socket_settimeout don't check negative values
12163 - CLEANUP: lua: typo fix in comments
12164 - BUILD/MINOR: fix build when USE_THREAD is not defined
12165 - MINOR: lua: allow socket api settimeout to accept integers, float, and doubles
12166 - BUG/MINOR: hpack: fix harmless use of uninitialized value in hpack_dht_insert
12167 - MINOR: cli/threads: make "show fd" report thread_sync_io_handler instead of "unknown"
12168 - MINOR: cli: make "show fd" report the mux and mux_ctx pointers when available
12169 - BUILD/MINOR: cli: fix a build warning introduced by last commit
12170 - BUG/MAJOR: h2: remove orphaned streams from the send list before closing
12171 - MINOR: h2: always call h2s_detach() in h2_detach()
12172 - MINOR: h2: fuse h2s_detach() and h2s_free() into h2s_destroy()
12173 - BUG/MEDIUM: h2/threads: never release the task outside of the task handler
12174 - BUG/MEDIUM: h2: don't consider pending data on detach if connection is in error
12175 - BUILD/MINOR: threads: always export thread_sync_io_handler()
12176 - MINOR: mux: add a "show_fd" function to dump debugging information for "show fd"
12177 - MINOR: h2: implement a basic "show_fd" function
12178 - MINOR: cli: report cache indexes in "show fd"
12179 - BUG/MINOR: h2: remove accidental debug code introduced with show_fd function
12180 - BUG/MEDIUM: h2: always add a stream to the send or fctl list when blocked
12181 - BUG/MINOR: checks: check the conn_stream's readiness and not the connection
12182 - BUG/MINOR: fd: Don't clear the update_mask in fd_insert.
12183 - BUG/MINOR: email-alert: Set the mailer port during alert initialization
12184 - BUG/MINOR: cache: fix "show cache" output
12185 - BUG/MAJOR: cache: fix random crashes caused by incorrect delete() on non-first blocks
12186 - BUG/MINOR: spoe: Initialize variables used during conf parsing before any check
12187 - BUG/MINOR: spoe: Don't release the context buffer in .check_timeouts callbaclk
12188 - BUG/MINOR: spoe: Register the variable to set when an error occurred
12189 - BUG/MINOR: spoe: Don't forget to decrement fpa when a processing is interrupted
12190 - MINOR: spoe: Add metrics in to know time spent in the SPOE
12191 - MINOR: spoe: Add options to store processing times in variables
12192 - MINOR: log: move 'log' keyword parsing in dedicated function
12193 - MINOR: log: Keep the ref when a log server is copied to avoid duplicate entries
12194 - MINOR: spoe: Add loggers dedicated to the SPOE agent
12195 - MINOR: spoe: Add support for option dontlog-normal in the SPOE agent section
12196 - MINOR: spoe: use agent's logger to log SPOE messages
12197 - MINOR: spoe: Add counters to log info about SPOE agents
12198 - BUG/MAJOR: cache: always initialize newly created objects
12199 - MINOR: servers: Support alphanumeric characters for the server templates names
12200 - BUG/MEDIUM: threads: Fix the max/min calculation because of name clashes
12201 - BUG/MEDIUM: connection: Make sure we have a mux before calling detach().
12202 - BUG/MINOR: http: Return an error in proxy mode when url2sa fails
12203 - MINOR: proxy: Add fe_defbe fetcher
12204 - MINOR: config: Warn if resolvers has no nameservers
12205 - BUG/MINOR: cli: Guard against NULL messages when using CLI_ST_PRINT_FREE
12206 - MINOR: cli: Ensure the CLI always outputs an error when it should
12207 - MEDIUM: sample: Extend functionality for field/word converters
12208 - MINOR: export localpeer as an environment variable
12209 - BUG/MEDIUM: kqueue: When adding new events, provide an output to get errors.
12210 - BUILD: sample: avoid build warning in sample.c
12211 - BUG/CRITICAL: h2: fix incorrect frame length check
12212 - DOC: lua: update the links to the config and Lua API
12213 - BUG/MINOR: pattern: Add a missing HA_SPIN_INIT() in pat_ref_newid()
12214 - BUG/MAJOR: channel: Fix crash when trying to read from a closed socket
12215 - BUG/MINOR: log: t_idle (%Ti) is not set for some requests
12216 - BUG/MEDIUM: lua: Fix segmentation fault if a Lua task exits
12217 - MINOR: h2: detect presence of CONNECT and/or content-length
12218 - BUG/MEDIUM: h2: implement missing support for chunked encoded uploads
12219 - BUG/MINOR: spoe: Fix counters update when processing is interrupted
12220 - BUG/MINOR: spoe: Fix parsing of dontlog-normal option
12221 - MEDIUM: cli: Add payload support
12222 - MINOR: map: Add payload support to "add map"
12223 - MINOR: ssl: Add payload support to "set ssl ocsp-response"
12224 - BUG/MINOR: lua/threads: Make lua's tasks sticky to the current thread
12225 - MINOR: sample: Add strcmp sample converter
12226 - MINOR: http: Add support for 421 Misdirected Request
12227 - BUG/MINOR: config: disable http-reuse on TCP proxies
12228 - MINOR: ssl: disable SSL sample fetches when unsupported
12229 - MINOR: ssl: add fetch 'ssl_fc_session_key' and 'ssl_bc_session_key'
12230 - BUG/MINOR: checks: Fix check->health computation for flapping servers
12231 - BUG/MEDIUM: threads: Fix the sync point for more than 32 threads
12232 - BUG/MINOR, BUG/MINOR: lua: Put tasks to sleep when waiting for data
12233 - MINOR: backend: implement random-based load balancing
12234 - DOC/MINOR: clean up LUA documentation re: servers & array/table.
12235 - MINOR: lua: Add server name & puid to LUA Server class.
12236 - MINOR: lua: add get_maxconn and set_maxconn to LUA Server class.
12237 - BUG/MINOR: map: correctly track reference to the last ref_elt being dumped
12238 - BUG/MEDIUM: task: Don't free a task that is about to be run.
12239 - MINOR: fd: Make the lockless fd list work with multiple lists.
12240 - BUG/MEDIUM: pollers: Use a global list for fd shared between threads.
12241 - MINOR: pollers: move polled_mask outside of struct fdtab.
12242 - BUG/MINOR: lua: schedule socket task upon lua connect()
12243 - BUG/MINOR: lua: ensure large proxy IDs can be represented
12244 - BUG/MEDIUM: pollers/kqueue: use incremented position in event list
12245 - BUG/MINOR: cli: don't stop cli_gen_usage_msg() when kw->usage == NULL
12246 - BUG/MEDIUM: http: don't always abort transfers on CF_SHUTR
12247 - BUG/MEDIUM: ssl: properly protect SSL cert generation
12248 - BUG/MINOR: lua: Socket.send threw runtime error: 'close' needs 1 arguments.
12249 - BUG/MINOR: spoe: Mistake in error message about SPOE configuration
12250 - BUG/MEDIUM: spoe: Flags are not encoded in network order
12251 - CLEANUP: spoe: Remove unused variables the agent structure
12252 - DOC: spoe: fix a typo
12253 - BUG/MEDIUM: contrib/mod_defender: Use network order to encode/decode flags
12254 - BUG/MEDIUM: contrib/modsecurity: Use network order to encode/decode flags
12255 - DOC: add some description of the pending rework of the buffer structure
12256 - BUG/MINOR: ssl/lua: prevent lua from affecting automatic maxconn computation
12257 - MINOR: lua: Improve error message
12258 - BUG/MEDIUM: cache: don't cache when an Authorization header is present
12259 - MINOR: ssl: set SSL_OP_PRIORITIZE_CHACHA
12260 - BUG/MEDIUM: dns: Delay the attempt to run a DNS resolution on check failure.
12261 - BUG/BUILD: threads: unbreak build without threads
12262 - BUG/MEDIUM: servers: Add srv_addr default placeholder to the state file
12263 - BUG/MEDIUM: lua/socket: Length required read doesn't work
12264 - MINOR: tasks: Change the task API so that the callback takes 3 arguments.
12265 - MAJOR: tasks: Create a per-thread runqueue.
12266 - MAJOR: tasks: Introduce tasklets.
12267 - MINOR: tasks: Make the number of tasks to run at once configurable.
12268 - MAJOR: applets: Use tasks, instead of rolling our own scheduler.
12269 - BUG/MEDIUM: stick-tables: Decrement ref_cnt in table_* converters
12270 - MINOR: http: Log warning if (add|set)-header fails
12271 - DOC: management: add the new wrew stats column
12272 - MINOR: stats: also report the failed header rewrites warnings on the stats page
12273 - BUG/MEDIUM: tasks: Don't forget to increase/decrease tasks_run_queue.
12274 - BUG/MEDIUM: task: Don't forget to decrement max_processed after each task.
12275 - MINOR: task: Also consider the task list size when getting global tasks.
12276 - MINOR: dns: Implement `parse-resolv-conf` directive
12277 - BUG/MEDIUM: spoe: Return an error when the wrong ACK is received in sync mode
12278 - MINOR: task/notification: Is notifications registered ?
12279 - BUG/MEDIUM: lua/socket: wrong scheduling for sockets
12280 - BUG/MAJOR: lua: Dead lock with sockets
12281 - BUG/MEDIUM: lua/socket: Notification error
12282 - BUG/MEDIUM: lua/socket: Sheduling error on write: may dead-lock
12283 - BUG/MEDIUM: lua/socket: Buffer error, may segfault
12284 - DOC: contrib/modsecurity: few typo fixes
12285 - DOC: SPOE.txt: fix a typo
12286 - MAJOR: spoe: upgrade the SPOP version to 2.0 and remove the support for 1.0
12287 - BUG/MINOR: contrib/spoa_example: Don't reset the status code during disconnect
12288 - BUG/MINOR: contrib/mod_defender: Don't reset the status code during disconnect
12289 - BUG/MINOR: contrib/modsecurity: Don't reset the status code during disconnect
12290 - BUG/MINOR: contrib/mod_defender: update pointer on the end of the frame
12291 - BUG/MINOR: contrib/modsecurity: update pointer on the end of the frame
12292 - MINOR: task: Fix a compiler warning by adding a cast.
12293 - MINOR: stats: also report the nice and number of calls for applets
12294 - MINOR: applet: assign the same nice value to a new appctx as its owner task
12295 - MINOR: task: Fix compiler warning.
12296 - BUG/MEDIUM: tasks: Use the local runqueue when building without threads.
12297 - MINOR: tasks: Don't define rqueue if we're building without threads.
12298 - BUG/MINOR: unix: Make sure we can transfer abns sockets on seamless reload.
12299 - MINOR: lua: Increase debug information
12300 - BUG/MEDIUM: threads: handle signal queue only in thread 0
12301 - BUG/MINOR: don't ignore SIG{BUS,FPE,ILL,SEGV} during signal processing
12302 - BUG/MINOR: signals: ha_sigmask macro for multithreading
12303 - BUG/MAJOR: map: fix a segfault when using http-request set-map
12304 - DOC: regression testing: Add a short starting guide.
12305 - MINOR: tasks: Make sure we correctly init and deinit a tasklet.
12306 - BUG/MINOR: tasklets: Just make sure we don't pass a tasklet to the handler.
12307 - BUG/MINOR: lua: Segfaults with wrong usage of types.
12308 - BUG/MAJOR: ssl: Random crash with cipherlist capture
12309 - BUG/MAJOR: ssl: OpenSSL context is stored in non-reserved memory slot
12310 - BUG/MEDIUM: ssl: do not store pkinfo with SSL_set_ex_data
12311 - MINOR: tests: First regression testing file.
12312 - MINOR: reg-tests: Add reg-tests/README file.
12313 - MINOR: reg-tests: Add a few regression testing files.
12314 - DOC: Add new REGTEST tag info about reg testing.
12315 - BUG/MEDIUM: fd: Don't modify the update_mask in fd_dodelete().
12316 - MINOR: Some spelling cleanup in the comments.
12317 - BUG/MEDIUM: threads: Use the sync point to check active jobs and exit
12318 - MINOR: threads: Be sure to remove threads from all_threads_mask on exit
12319 - REGTEST/MINOR: Wrong URI in a reg test for SSL/TLS.
12320 - REGTEST/MINOR: Set HAPROXY_PROGRAM default value.
12321 - REGTEST/MINOR: Add levels to reg-tests target.
12322 - BUG/MAJOR: Stick-tables crash with segfault when the key is not in the stick-table
12323 - BUG/BUILD: threads: unbreak build without threads
12324 - BUG/MAJOR: stick_table: Complete incomplete SEGV fix
12325 - MINOR: stick-tables: make stktable_release() do nothing on NULL
12326 - BUG/MEDIUM: lua: possible CLOSE-WAIT state with '\n' headers
12327 - MINOR: startup: change session/process group settings
12328 - MINOR: systemd: consider exit status 143 as successful
12329 - REGTEST/MINOR: Wrong URI syntax.
12330 - CLEANUP: dns: remove obsolete macro DNS_MAX_IP_REC
12331 - CLEANUP: dns: inacurate comment about prefered IP score
12332 - MINOR: dns: fix wrong score computation in dns_get_ip_from_response
12333 - MINOR: dns: new DNS options to allow/prevent IP address duplication
12334 - REGTEST/MINOR: Unexpected curl URL globling.
12335 - BUG/MINOR: ssl: properly ref-count the tls_keys entries
12336 - MINOR: h2: keep a count of the number of conn_streams attached to the mux
12337 - BUG/MEDIUM: h2: don't accept new streams if conn_streams are still in excess
12338 - MINOR: h2: add the mux and demux buffer lengths on "show fd"
12339 - BUG/MEDIUM: h2: never leave pending data in the output buffer on close
12340 - BUG/MEDIUM: h2: make sure the last stream closes the connection after a timeout
12341 - MINOR: tasklet: Set process to NULL.
12342 - MINOR: buffer: implement a new file for low-level buffer manipulation functions
12343 - MINOR: buffer: switch buffer sizes and offsets to size_t
12344 - MINOR: buffer: add a few basic functions for the new API
12345 - MINOR: buffer: Introduce b_sub(), b_add(), and bo_add()
12346 - MINOR: buffer: Add b_set_data().
12347 - MINOR: buffer: introduce b_realign_if_empty()
12348 - MINOR: compression: pass the channel to http_compression_buffer_end()
12349 - MINOR: channel: add a few basic functions for the new buffer API
12350 - MINOR: channel/buffer: use c_realign_if_empty() instead of buffer_realign()
12351 - MINOR: channel/buffer: replace buffer_slow_realign() with channel_slow_realign() and b_slow_realign()
12352 - MEDIUM: channel: make channel_slow_realign() take a swap buffer
12353 - MINOR: h2: use b_slow_realign() with the trash as a swap buffer
12354 - MINOR: buffer: remove buffer_slow_realign() and the swap_buffer allocation code
12355 - MINOR: channel/buffer: replace b_{adv,rew} with c_{adv,rew}
12356 - MINOR: buffer: replace calls to buffer_space_wraps() with b_space_wraps()
12357 - MINOR: buffer: remove bi_getblk() and bi_getblk_nc()
12358 - MINOR: buffer: split bi_contig_data() into ci_contig_data and b_config_data()
12359 - MINOR: buffer: remove bi_ptr()
12360 - MINOR: buffer: remove bo_ptr()
12361 - MINOR: buffer: remove bo_end()
12362 - MINOR: buffer: remove bi_end()
12363 - MINOR: buffer: remove bo_contig_data()
12364 - MINOR: buffer: merge b{i,o}_contig_space()
12365 - MINOR: buffer: replace bo_getblk() with direction agnostic b_getblk()
12366 - MINOR: buffer: replace bo_getblk_nc() with b_getblk_nc() which takes an offset
12367 - MINOR: buffer: replace bi_del() and bo_del() with b_del()
12368 - MINOR: buffer: convert most b_ptr() calls to c_ptr()
12369 - MINOR: h1: make h1_measure_trailers() take the byte count in argument
12370 - MINOR: h2: clarify the fact that the send functions are unsigned
12371 - MEDIUM: h2: prevent the various mux encoders from modifying the buffer
12372 - MINOR: h1: make h1_skip_chunk_crlf() not depend on b_ptr() anymore
12373 - MINOR: h1: make h1_parse_chunk_size() not depend on b_ptr() anymore
12374 - MINOR: h1: make h1_measure_trailers() use an offset and a count
12375 - MEDIUM: h2: do not use buf->o anymore inside h2_snd_buf's loop
12376 - MEDIUM: h2: don't use b_ptr() nor b_end() anymore
12377 - MINOR: buffer: get rid of b_end() and b_to_end()
12378 - MINOR: buffer: make b_getblk_nc() take const pointers
12379 - MINOR: buffer: make b_getblk_nc() take size_t for the block sizes
12380 - MEDIUM: connection: make xprt->snd_buf() take the byte count in argument
12381 - MEDIUM: mux: make mux->snd_buf() take the byte count in argument
12382 - MEDIUM: connection: make xprt->rcv_buf() use size_t for the count
12383 - MEDIUM: mux: make mux->rcv_buf() take a size_t for the count
12384 - MINOR: connection: add a flags argument to rcv_buf()
12385 - MINOR: connection: add a new receive flag : CO_RFL_BUF_WET
12386 - MINOR: buffer: get rid of b_ptr() and convert its last users
12387 - MINOR: buffer: use b_room() to determine available space in a buffer
12388 - MINOR: buffer: replace buffer_not_empty() with b_data() or c_data()
12389 - MINOR: buffer: replace buffer_empty() with b_empty() or c_empty()
12390 - MINOR: buffer: make bo_putchar() use b_tail()
12391 - MINOR: buffer: replace buffer_full() with channel_full()
12392 - MINOR: buffer: replace bi_space_for_replace() with ci_space_for_replace()
12393 - MINOR: buffer: replace buffer_pending() with ci_data()
12394 - MINOR: buffer: replace buffer_flush() with c_adv(chn, ci_data(chn))
12395 - MINOR: buffer: use c_head() instead of buffer_wrap_sub(c->buf, p-o)
12396 - MINOR: buffer: use b_orig() to replace most references to b->data
12397 - MINOR: buffer: Use b_add()/bo_add() instead of accessing b->i/b->o.
12398 - MINOR: channel: remove almost all references to buf->i and buf->o
12399 - MINOR: channel: Add co_set_data().
12400 - MEDIUM: channel: adapt to the new buffer API
12401 - MINOR: checks: adapt to the new buffer API
12402 - MEDIUM: h2: update to the new buffer API
12403 - MINOR: buffer: remove unused bo_add()
12404 - MEDIUM: spoe: use the new buffer API for the SPOE buffer
12405 - MINOR: stats: adapt to the new buffers API
12406 - MINOR: cli: use the new buffer API
12407 - MINOR: cache: use the new buffer API
12408 - MINOR: stream-int: use the new buffer API
12409 - MINOR: stream: use wrappers instead of directly manipulating buffers
12410 - MINOR: backend: use new buffer API
12411 - MEDIUM: http: use wrappers instead of directly manipulating buffers states
12412 - MINOR: filters: convert to the new buffer API
12413 - MINOR: payload: convert to the new buffer API
12414 - MEDIUM: h1: port to new buffer API.
12415 - MINOR: flt_trace: adapt to the new buffer API
12416 - MEDIUM: compression: start to move to the new buffer API
12417 - MINOR: lua: use the wrappers instead of directly manipulating buffer states
12418 - MINOR: buffer: convert part bo_putblk() and bi_putblk() to the new API
12419 - MINOR: buffer: adapt buffer_slow_realign() and buffer_dump() to the new API
12420 - MAJOR: start to change buffer API
12421 - MINOR: buffer: remove the check for output on b_del()
12422 - MINOR: buffer: b_set_data() doesn't truncate output data anymore
12423 - MINOR: buffer: rename the "data" field to "area"
12424 - MEDIUM: buffers: move "output" from struct buffer to struct channel
12425 - MINOR: buffer: replace bi_fast_delete() with b_del()
12426 - MINOR: buffer: replace b{i,o}_put* with b_put*
12427 - MINOR: buffer: add a new file for ist + buffer manipulation functions
12428 - MINOR: checks: use b_putist() instead of b_putstr()
12429 - MINOR: buffers: remove b_putstr()
12430 - CLEANUP: buffer: minor cleanups to buffer.h
12431 - MINOR: buffers/channel: replace buffer_insert_line2() with ci_insert_line2()
12432 - MINOR: buffer: replace buffer_replace2() with b_rep_blk()
12433 - MINOR: buffer: rename the data length member to '->data'
12434 - MAJOR: buffer: finalize buffer detachment
12435 - MEDIUM: chunks: make the chunk struct's fields match the buffer struct
12436 - MAJOR: chunks: replace struct chunk with struct buffer
12437 - DOC: buffers: document the new buffers API
12438 - DOC: buffers: remove obsolete docs about buffers
12439 - MINOR: tasklets: Don't attempt to add a tasklet in the list twice.
12440 - MINOR: connections/mux: Add a new "subscribe" method.
12441 - MEDIUM: connections/mux: Revamp the send direction.
12442 - MINOR: connection: simplify subscription by adding a registration function
12443 - BUG/MINOR: http: Set brackets for the unlikely macro at the right place
12444 - BUG/MINOR: build: Fix compilation with debug mode enabled
12445 - BUILD: Generate sha256 checksums in publish-release
12446 - MINOR: debug: Add check for CO_FL_WILL_UPDATE
12447 - MINOR: debug: Add checks for conn_stream flags
12448 - MINOR: ist: Add the function isteqi
12449 - BUG/MEDIUM: threads: Fix the exit condition of the thread barrier
12450 - BUG/MEDIUM: mux_h2: Call h2_send() before updating polling.
12451 - MINOR: buffers: simplify b_contig_space()
12452 - MINOR: buffers: split b_putblk() into __b_putblk()
12453 - MINOR: buffers: add b_xfer() to transfer data between buffers
12454 - DOC: add some design notes about the new layering model
12455 - MINOR: conn_stream: add a new CS_FL_REOS flag
12456 - MINOR: conn_stream: add an rx buffer to the conn_stream
12457 - MEDIUM: conn_stream: add cs_recv() as a default rcv_buf() function
12458 - MEDIUM: stream-int: automatically call si_cs_recv_cb() if the cs has data on wake()
12459 - MINOR: h2: make each H2 stream support an intermediary input buffer
12460 - MEDIUM: h2: make h2_frt_decode_headers() use an intermediary buffer
12461 - MEDIUM: h2: make h2_frt_transfer_data() copy via an intermediary buffer
12462 - MEDIUM: h2: centralize transfer of decoded frames in h2_rcv_buf()
12463 - MEDIUM: h2: move headers and data frame decoding to their respective parsers
12464 - MEDIUM: buffers: make b_xfer() automatically swap buffers when possible
12465 - MEDIUM: h2: perform a single call to the data layer in demux()
12466 - MEDIUM: h2: don't call data_cb->recv() anymore
12467 - MINOR: h2: make use of CS_FL_REOS to indicate that end of stream was seen
12468 - MEDIUM: h2: use the default conn_stream's receive function
12469 - DOC: add more design feedback on the new layering model
12470 - MINOR: h2: add the error code and the max/last stream IDs to "show fd"
12471 - BUG/MEDIUM: stream-int: don't immediately enable reading when the buffer was reportedly full
12472 - BUG/MEDIUM: stats: don't ask for more data as long as we're responding
12473 - BUG/MINOR: servers: Don't make "server" in a frontend fatal.
12474 - BUG/MEDIUM: tasks: make sure we pick all tasks in the run queue
12475 - BUG/MEDIUM: tasks: Decrement rqueue_size at the right time.
12476 - BUG/MEDIUM: tasks: use atomic ops for active_tasks_mask
12477 - BUG/MEDIUM: tasks: Make sure there's no task left before considering inactive.
12478 - MINOR: signal: don't pass the signal number anymore as the wakeup reason
12479 - MINOR: tasks: extend the state bits from 8 to 16 and remove the reason
12480 - MINOR: tasks: Add a flag that tells if we're in the global runqueue.
12481 - BUG/MEDIUM: tasks: make __task_unlink_rq responsible for the rqueue size.
12482 - MINOR: queue: centralize dequeuing code a bit better
12483 - MEDIUM: queue: make pendconn_free() work on the stream instead
12484 - DOC: queue: document the expected locking model for the server's queue
12485 - MINOR: queue: make sure pendconn->strm->pend_pos is always valid
12486 - MINOR: queue: use a distinct variable for the assigned server and the queue
12487 - MINOR: queue: implement pendconn queue locking functions
12488 - MEDIUM: queue: get rid of the pendconn lock
12489 - MINOR: tasks: Make active_tasks_mask volatile.
12490 - MINOR: tasks: Make global_tasks_mask volatile.
12491 - MINOR: pollers: Add a way to wake a thread sleeping in the poller.
12492 - MINOR: threads/queue: Get rid of THREAD_WANT_SYNC in the queue code.
12493 - BUG/MEDIUM: threads/sync: use sched_yield when available
12494 - MINOR: ssl: BoringSSL matches OpenSSL 1.1.0
12495 - BUG/MEDIUM: h2: prevent orphaned streams from blocking a connection forever
12496 - BUG/MINOR: config: stick-table is not supported in defaults section
12497 - BUILD/MINOR: threads: unbreak build with threads disabled
12498 - BUG/MINOR: threads: Handle nbthread == MAX_THREADS.
12499 - BUG/MEDIUM: threads: properly fix nbthreads == MAX_THREADS
12500 - MINOR: threads: move "nbthread" parsing to hathreads.c
12501 - BUG/MEDIUM: threads: unbreak "bind" referencing an incorrect thread number
12502 - MEDIUM: proxy_protocol: Convert IPs to v6 when protocols are mixed
12503 - BUILD/MINOR: compiler: fix offsetof() on older compilers
12504 - SCRIPTS: git-show-backports: add missing quotes to "echo"
12505 - MINOR: threads: add more consistency between certain variables in no-thread case
12506 - MEDIUM: hathreads: implement a more flexible rendez-vous point
12507 - BUG/MEDIUM: cli: make "show fd" thread-safe
12508
Willy Tarreaub3066502017-11-26 19:50:17 +0100125092017/11/26 : 1.9-dev0
12510
Willy Tarreau0b787922017-11-26 19:25:23 +0100125112017/11/26 : 1.8.0
12512 - BUG/MEDIUM: stream: don't automatically forward connect nor close
12513 - BUG/MAJOR: stream: ensure analysers are always called upon close
12514 - BUG/MINOR: stream-int: don't try to read again when CF_READ_DONTWAIT is set
12515 - MEDIUM: mworker: Add systemd `Type=notify` support
12516 - BUG/MEDIUM: cache: free callback to remove from tree
12517 - CLEANUP: cache: remove unused struct
12518 - MEDIUM: cache: enable the HTTP analysers
12519 - CLEANUP: cache: remove wrong comment
12520 - MINOR: threads/atomic: rename local variables in macros to avoid conflicts
12521 - MINOR: threads/plock: rename local variables in macros to avoid conflicts
12522 - MINOR: threads/atomic: implement pl_mb() in asm on x86
12523 - MINOR: threads/atomic: implement pl_bts() on non-x86
12524 - MINOR: threads/build: atomic: replace the few inlines with macros
12525 - BUILD: threads/plock: fix a build issue on Clang without optimization
12526 - BUILD: ebtree: don't redefine types u32/s32 in scope-aware trees
12527 - BUILD: compiler: add a new type modifier __maybe_unused
12528 - BUILD: h2: mark some inlined functions "unused"
12529 - BUILD: server: check->desc always exists
12530 - BUG/MEDIUM: h2: properly report connection errors in headers and data handlers
12531 - MEDIUM: h2: add a function to emit an HTTP/1 request from a headers list
12532 - MEDIUM: h2: change hpack_decode_headers() to only provide a list of headers
12533 - BUG/MEDIUM: h2: always reassemble the Cookie request header field
12534 - BUG/MINOR: systemd: ignore daemon mode
12535 - CONTRIB: spoa_example: allow to compile outside HAProxy.
12536 - CONTRIB: spoa_example: remove bref, wordlist, cond_wordlist
12537 - CONTRIB: spoa_example: remove last dependencies on type "sample"
12538 - CONTRIB: spoa_example: remove SPOE enums that are useless for clients
12539 - CLEANUP: cache: reorder includes
12540 - MEDIUM: shctx: use unsigned int for len and block_count
12541 - MEDIUM: cache: "show cache" on the cli
12542 - BUG/MEDIUM: cache: use key=0 as a condition for freeing
12543 - BUG/MEDIUM: cache: refcount forbids to free the objects
12544 - BUG/MEDIUM: cache fix cli_kws structure
12545 - BUG/MEDIUM: deinit: correctly deinitialize the proxy and global listener tasks
12546 - BUG/MINOR: ssl: Always start the handshake if we can't send early data.
12547 - MINOR: ssl: Don't disable early data handling if we could not write.
12548 - MINOR: pools: prepare functions to override malloc/free in pools
12549 - MINOR: pools: implement DEBUG_UAF to detect use after free
12550 - BUG/MEDIUM: threads/time: fix time drift correction
12551 - BUG/MEDIUM: threads/time: maintain a common time reference between all threads
12552 - MINOR: sample: Add "thread" sample fetch
12553 - BUG/MINOR: Use crt_base instead of ca_base when crt is parsed on a server line
12554 - BUG/MINOR: stream: fix tv_request calculation for applets
12555 - BUG/MAJOR: h2: always remove a stream from the send list before freeing it
12556 - BUG/MAJOR: threads/task: dequeue expired tasks under the WQ lock
12557 - MINOR: ssl: Handle reading early data after writing better.
12558 - MINOR: mux: Make sure every string is woken up after the handshake.
12559 - MEDIUM: cache: store sha1 for hashing the cache key
12560 - MINOR: http: implement the "http-request reject" rule
12561 - MINOR: h2: send RST_STREAM before GOAWAY on reject
12562 - MEDIUM: h2: don't gracefully close the connection anymore on Connection: close
12563 - MINOR: h2: make use of client-fin timeout after GOAWAY
12564 - MEDIUM: config: ensure that tune.bufsize is at least 16384 when using HTTP/2
12565 - MINOR: ssl: Handle early data with BoringSSL
12566 - BUG/MEDIUM: stream: always release the stream-interface on abort
12567 - BUG/MEDIUM: cache: free ressources in chn_end_analyze
12568 - MINOR: cache: move the refcount decrease in the applet release
12569 - BUG/MINOR: listener: Allow multiple "process" options on "bind" lines
12570 - MINOR: config: Support a range to specify processes in "cpu-map" parameter
12571 - MINOR: config: Slightly change how parse_process_number works
12572 - MINOR: config: Export parse_process_number and use it wherever it's applicable
12573 - MINOR: standard: Add my_ffsl function to get the position of the bit set to one
12574 - MINOR: config: Add auto-increment feature for cpu-map
12575 - MINOR: config: Support partial ranges in cpu-map directive
12576 - MINOR:: config: Remove thread-map directive
12577 - MINOR: config: Add the threads support in cpu-map directive
12578 - MINOR: config: Add threads support for "process" option on "bind" lines
12579 - MEDIUM: listener: Bind listeners on a thread subset if specified
12580 - CLEANUP: debug: Use DPRINTF instead of fprintf into #ifdef DEBUG_FULL/#endif
12581 - CLEANUP: log: Rename Alert/Warning in ha_alert/ha_warning
12582 - MINOR/CLEANUP: proxy: rename "proxy" to "proxies_list"
12583 - CLEANUP: pools: rename all pool functions and pointers to remove this "2"
12584 - DOC: update the roadmap file with the latest changes merged in 1.8
12585 - DOC: fix mangled version in peers protocol documentation
12586 - DOC: add initial peers protovol v2.0 documentation.
12587 - DOC: mention William as maintainer of the cache and master-worker
12588 - DOC: add Christopher and Emeric as maintainers of the threads
12589 - MINOR: cache: replace a fprint() by an abort()
12590 - MEDIUM: cache: max-age configuration keyword
12591 - DOC: explain HTTP2 timeout behavior
12592 - DOC: cache: configuration and management
12593 - MAJOR: mworker: exits the master on failure
12594 - BUG/MINOR: threads: don't drop "extern" on the lock in include files
12595 - MINOR: task: keep a pointer to the currently running task
12596 - MINOR: task: align the rq and wq locks
12597 - MINOR: fd: cache-align fdtab and fdcache locks
12598 - MINOR: buffers: cache-align buffer_wq_lock
12599 - CLEANUP: server: reorder some fields in struct server to save 40 bytes
12600 - CLEANUP: proxy: slightly reorder the struct proxy to reduce holes
12601 - CLEANUP: checks: remove 16 bytes of holes in struct check
12602 - CLEANUP: cache: more efficiently pack the struct cache
12603 - CLEANUP: fd: place the lock at the beginning of struct fdtab
12604 - CLEANUP: pools: align pools on a cache line
12605 - DOC: config: add a few bits about how to configure HTTP/2
12606 - BUG/MAJOR: threads/queue: avoid recursive locking in pendconn_get_next_strm()
12607 - BUILD: Makefile: reorder object files by size
12608
Willy Tarreaucfe14662017-11-19 09:55:29 +0100126092017/11/19 : 1.8-rc4
12610 - BUG/MEDIUM: cache: does not cache if no Content-Length
12611 - BUILD: thread/pipe: fix build without threads
12612 - BUG/MINOR: spoe: check buffer size before acquiring or releasing it
12613 - MINOR: debug/flags: Add missing flags
12614 - MINOR: threads: Use __decl_hathreads to declare locks
12615 - BUG/MINOR: buffers: Fix b_alloc_margin to be "fonctionnaly" thread-safe
12616 - BUG/MAJOR: ebtree/scope: fix insertion and removal of duplicates in scope-aware trees
12617 - BUG/MAJOR: ebtree/scope: fix lookup of next node in scope-aware trees
12618 - MINOR: ebtree/scope: add a function to find next node from a parent
12619 - MINOR: ebtree/scope: simplify the lookup functions by using eb32sc_next_with_parent()
12620 - BUG/MEDIUM: mworker: Fix re-exec when haproxy is started from PATH
12621 - BUG/MEDIUM: cache: use msg->sov to forward header
12622 - MINOR: cache: forward data with headers
12623 - MINOR: cache: disable cache if shctx_row_data_append fail
12624 - BUG/MINOR: threads: tid_bit must be a unsigned long
12625 - CLEANUP: tasks: Remove useless double test on rq_next
12626 - BUG/MEDIUM: standard: itao_str/idx and quote_str/idx must be thread-local
12627 - MINOR: tools: add a function to dump a scope-aware tree to a file
12628 - MINOR: tools: improve the DOT dump of the ebtree
12629 - MINOR: tools: emphasize the node being worked on in the tree dump
12630 - BUG/MAJOR: ebtree/scope: properly tag upper nodes during insertion
12631 - DOC: peers: Add a first version of peers protocol v2.1.
12632 - CONTRIB: Wireshark dissector for HAProxy Peer Protocol.
12633 - MINOR: mworker: display an accurate error when the reexec fail
12634 - BUG/MEDIUM: mworker: wait again for signals when execvp fail
12635 - BUG/MEDIUM: mworker: does not deinit anymore
12636 - BUG/MEDIUM: mworker: does not close inherited FD
12637 - MINOR: tests: add a python wrapper to test inherited fd
12638 - BUG/MINOR: Allocate the log buffers before the proxies startup
12639 - MINOR: tasks: Use a bitfield to track tasks activity per-thread
12640 - MAJOR: polling: Use active_tasks_mask instead of tasks_run_queue
12641 - MINOR: applets: Use a bitfield to track applets activity per-thread
12642 - MAJOR: polling: Use active_appels_mask instead of applets_active_queue
12643 - MEDIUM: applets: Don't process more than 200 active applets at once
12644 - MINOR: stream: Add thread-mask of tasks/FDs/applets in "show sess all" command
12645 - MINOR: SSL: Store the ASN1 representation of client sessions.
12646 - MINOR: ssl: Make sure we don't shutw the connection before the handshake.
12647 - BUG/MEDIUM: deviceatlas: ignore not valuable HTTP request data
12648
Willy Tarreau34650d52017-11-11 09:06:48 +0100126492017/11/11 : 1.8-rc3
12650 - BUILD: use MAXPATHLEN instead of NAME_MAX.
12651 - BUG/MAJOR: threads/checks: add 4 missing spin_unlock() in various functions
12652 - BUG/MAJOR: threads/server: missing unlock in CLI fqdn parser
12653 - BUG/MINOR: cli: do not perform an invalid action on "set server check-port"
12654 - BUG/MAJOR: threads/checks: wrong use of SPIN_LOCK instead of SPIN_UNLOCK
12655 - CLEANUP: checks: remove return statements in locked functions
12656 - BUG/MINOR: cli: add severity in "set server addr" parser
12657 - CLEANUP: server: get rid of return statements in the CLI parser
12658 - BUG/MAJOR: cli/streams: missing unlock on exit "show sess"
12659 - BUG/MAJOR: threads/dns: add missing unlock on allocation failure path
12660 - BUG/MAJOR: threads/lb: fix missing unlock on consistent hash LB
12661 - BUG/MAJOR: threads/lb: fix missing unlock on map-based hash LB
12662 - BUG/MEDIUM: threads/stick-tables: close a race condition on stktable_trash_expired()
12663 - BUG/MAJOR: h2: set the connection's task to NULL when no client timeout is set
12664 - BUG/MAJOR: thread/listeners: enable_listener must not call unbind_listener()
12665 - BUG/MEDIUM: threads: don't try to free build option message on exit
12666 - MINOR: applets: no need to check for runqueue's emptiness in appctx_res_wakeup()
12667 - MINOR: add master-worker in the warning about nbproc
12668 - MINOR: mworker: allow pidfile in mworker + foreground
12669 - MINOR: mworker: write parent pid in the pidfile
12670 - MINOR: mworker: do not store child pid anymore in the pidfile
12671 - MINOR: ebtree: implement the scope-aware functions for eb32
12672 - MEDIUM: ebtree: specify the scope of every node inserted via eb32sc
12673 - MINOR: ebtree: update the eb32sc parent node's scope on delete
12674 - MEDIUM: ebtree: only consider the branches matching the scope in lookups
12675 - MINOR: ebtree: implement eb32sc_lookup_ge_or_first()
12676 - MAJOR: task: make use of the scope-aware ebtree functions
12677 - MINOR: task: simplify wake_expired_tasks() to avoid unlocking in the loop
12678 - MEDIUM: task: change the construction of the loop in process_runnable_tasks()
12679 - MINOR: threads: use faster locks for the spin locks
12680 - MINOR: tasks: only visit filled task slots after processing them
12681 - MEDIUM: tasks: implement a lockless scheduler for single-thread usage
12682 - BUG/MINOR: dns: Don't try to get the server lock if it's already held.
12683 - BUG/MINOR: dns: Don't lock the server lock in snr_check_ip_callback().
12684 - DOC: Add note about encrypted password CPU usage
12685 - BUG/MINOR: h2: set the "HEADERS_SENT" flag on stream, not connection
12686 - BUG/MEDIUM: h2: properly send an RST_STREAM on mux stream error
12687 - BUG/MEDIUM: h2: properly send the GOAWAY frame in the mux
12688 - BUG/MEDIUM: h2: don't try (and fail) to send non-existing data in the mux
12689 - MEDIUM: h2: remove the H2_SS_RESET intermediate state
12690 - BUG/MEDIUM: h2: fix some wrong error codes on connections
12691 - BUILD: threads: Rename SPIN/RWLOCK macros using HA_ prefix
12692 - BUILD: enable USE_THREAD for Solaris build.
12693 - BUG/MEDIUM: h2: don't close the connection is there are data left
12694 - MINOR: h2: don't re-enable the connection's task when we're closing
12695 - BUG/MEDIUM: h2: properly set H2_SF_ES_SENT when sending the final frame
12696 - BUG/MINOR: h2: correctly check for H2_SF_ES_SENT before closing
12697 - MINOR: h2: add new stream flag H2_SF_OUTGOING_DATA
12698 - BUG/MINOR: h2: don't send GOAWAY on failed response
12699 - BUG/MEDIUM: splice/threads: pipe reuse list was not protected.
12700 - BUG/MINOR: comp: fix compilation warning compiling without compression.
12701 - BUG/MINOR: stream-int: don't set MSG_MORE on closed request path
12702 - BUG/MAJOR: threads/tasks: fix the scheduler again
12703 - BUG/MINOR; ssl: Don't assume we have a ssl_bind_conf because a SNI is matched.
12704 - MINOR: ssl: Handle session resumption with TLS 1.3
12705 - MINOR: ssl: Spell 0x10101000L correctly.
12706 - MINOR: ssl: Handle sending early data to server.
12707 - BUILD: ssl: fix build of backend without ssl
12708 - BUILD: shctx: do not depend on openssl anymore
12709 - BUG/MINOR: h1: the HTTP/1 make status code parser check for digits
12710 - BUG/MEDIUM: h2: reject non-3-digit status codes
12711 - BUG/MEDIUM: stream-int: Don't loss write's notifs when a stream is woken up
12712 - BUG/MINOR: pattern: Rely on the sample type to copy it in pattern_exec_match
12713 - BUG/MEDIUM: h2: split the function to send RST_STREAM
12714 - BUG/MEDIUM: h1: ensure the chunk size parser can deal with full buffers
12715 - MINOR: tools: don't use unlikely() in hex2i()
12716 - BUG/MEDIUM: h2: support orphaned streams
12717 - BUG/MEDIUM: threads/cli: fix "show sess" locking on release
12718 - CLEANUP: mux: remove the unused "release()" function
12719 - MINOR: cli: make "show fd" report the fd's thread mask
12720 - BUG/MEDIUM: stream: don't ignore res.analyse_exp anymore
12721 - CLEANUP: global: introduce variable pid_bit to avoid shifts with relative_pid
12722 - MEDIUM: http: always reject the "PRI" method
12723
Willy Tarreaua8d8d6e2017-11-03 23:52:47 +0100127242017/11/03 : 1.8-rc2
12725 - BUG/MINOR: send-proxy-v2: fix dest_len in make_tlv call
12726 - BUG/MINOR: send-proxy-v2: string size must include ('\0')
12727 - MINOR: mux: Only define pipe functions on linux.
12728 - MINOR: cache: Remove useless test for nonzero.
12729 - MINOR: cache: Don't confuse act_return and act_parse_ret.
12730 - BUG/MEDIUM: h2: don't try to parse incomplete H1 responses
12731 - BUG/MEDIUM: checks/mux: always enable send-polling after connecting
12732 - BUG/MAJOR: fix deadlock on healthchecks.
12733 - BUG/MINOR: thread: fix a typo in the debug code
12734 - BUILD: shctx: allow to be built without openssl
12735 - BUG/MEDIUM: cache: don't try to resolve wrong filters
12736 - BUG/MAJOR: buffers: fix get_buffer_nc() for data at end of buffer
12737 - BUG/MINOR: freq: fix infinite loop on freq_ctr_period.
12738 - BUG/MINOR: stdarg.h inclusion
12739 - BUG/MINOR: dns: fix missing lock protection on server.
12740 - BUG/MINOR: lua: fix missing lock protection on server.
12741 - BUILD: enable USE_THREAD for OpenBSD build.
12742 - BUG/MAJOR: mux_pt: don't dereference a connstream after ->wake()
12743 - MINOR: thread: report multi-thread support in haproxy -vv
12744
Willy Tarreau901f75c2017-10-31 23:18:29 +0100127452017/10/31 : 1.8-rc1
12746 - BUG/MEDIUM: server: Allocate tmptrash before using it.
12747 - CONTRIB: trace: add the possibility to place trace calls in the code
12748 - CONTRIB: trace: try to display the function's return value on exit
12749 - CONTRIB: trace: report the base name only for file names
12750 - BUILD: ssl: support OPENSSL_NO_ASYNC #define
12751 - MINOR: ssl: build with recent BoringSSL library
12752 - BUG/MINOR: ssl: OCSP_single_get0_status can return -1
12753 - BUG/MINOR: cli: restore "set ssl tls-key" command
12754 - CLEANUP: cli: remove undocumented "set ssl tls-keys" command
12755 - IMPORT: sha1: import SHA1 functions
12756 - MINOR: sample: add the sha1 converter
12757 - MINOR: sample: add the hex2i converter
12758 - MINOR: stream-int: stop checking for useless connection flags in chk_snd_conn
12759 - MINOR: ssl: don't abort after sending 16kB
12760 - MINOR: connection: move the cleanup of flag CO_FL_WAIT_ROOM
12761 - MINOR: connection: add flag CO_FL_WILL_UPDATE to indicate when updates are granted
12762 - MEDIUM: connection: make use of CO_FL_WILL_UPDATE in conn_sock_shutw()
12763 - MINOR: raw_sock: make use of CO_FL_WILL_UPDATE
12764 - MINOR: ssl_sock: make use of CO_FL_WILL_UPDATE
12765 - BUG/MINOR: checks: Don't forget to release the connection on error case.
12766 - MINOR: buffer: add the buffer input manipulation functions
12767 - BUG/MEDIUM: prevent buffers being overwritten during build_logline() execution
12768 - MEDIUM: cfgparse: post section callback
12769 - MEDIUM: cfgparse: post parsing registration
12770 - MINOR: lua: add uuid to the Class Proxy
12771 - MINOR: hlua: Add regex class
12772 - MINOR: http: Mark the 425 code as "Too Early".
12773 - MEDIUM: ssl: convert CBS (BoringSSL api) usage to neutral code
12774 - MINOR: ssl: support Openssl 1.1.1 early callback for switchctx
12775 - MINOR: ssl: generated certificate is missing in switchctx early callback
12776 - MEDIUM: ssl: Handle early data with OpenSSL 1.1.1
12777 - BUILD: Makefile: disable -Wunused-label
12778 - MINOR: ssl/proto_http: Add keywords to take care of early data.
12779 - BUG/MINOR: lua: const attribute of a string is overridden
12780 - MINOR: ssl: Don't abuse ssl_options.
12781 - MINOR: update proxy-protocol-v2 #define
12782 - MINOR: merge ssl_sock_get calls for log and ppv2
12783 - MINOR: add ALPN information to send-proxy-v2
12784 - MEDIUM: h1: ensure that 1xx, 204 and 304 don't have a payload body
12785 - CLEANUP: shctx: get ride of the shsess_packet{_hdr} structures
12786 - MEDIUM: lists: list_for_each_entry{_safe}_from functions
12787 - REORG: shctx: move lock functions and struct
12788 - MEDIUM: shctx: allow the use of multiple shctx
12789 - REORG: shctx: move ssl functions to ssl_sock.c
12790 - MEDIUM: shctx: separate ssl and shctx
12791 - MINOR: shctx: rename lock functions
12792 - MINOR: h1: store the status code in the H1 message
12793 - BUG/MINOR: spoe: Don't compare engine name and SPOE scope when both are NULL
12794 - BUG/MINOR: spoa: Update pointer on the end of the frame when a reply is encoded
12795 - MINOR: action: Add trk_idx inline function
12796 - MINOR: action: Use trk_idx instead of tcp/http_trk_idx
12797 - MINOR: action: Add a function pointer in act_rule struct to check its validity
12798 - MINOR: action: Add function to check rules using an action ACT_ACTION_TRK_*
12799 - MINOR: action: Add a functions to check http capture rules
12800 - MINOR: action: Factorize checks on rules calling check_ptr if defined
12801 - MINOR: acl: Pass the ACLs as an explicit parameter of build_acl_cond
12802 - MEDIUM: spoe: Add support of ACLS to enable or disable sending of SPOE messages
12803 - MINOR: spoe: Check uniqness of SPOE engine names during config parsing
12804 - MEDIUM: spoe: Parse new "spoe-group" section in SPOE config file
12805 - MEDIUM: spoe/rules: Add "send-spoe-group" action for tcp/http rules
12806 - MINOR: spoe: Move message encoding in its own function
12807 - MINOR: spoe: Add a type to qualify the message list during encoding
12808 - MINOR: spoe: Add a generic function to encode a list of SPOE message
12809 - MEDIUM: spoe/rules: Process "send-spoe-group" action
12810 - BUG/MINOR: dns: Fix CLI keyword declaration
12811 - MAJOR: dns: Refactor the DNS code
12812 - BUG/MINOR: mailers: Fix a memory leak when email alerts are released
12813 - MEDIUM: mailers: Init alerts during conf parsing and refactor their processing
12814 - MINOR: mailers: Use pools to allocate email alerts and its tcpcheck_rules
12815 - MINOR: standard: Add memvprintf function
12816 - MINOR: log: Save alerts and warnings emitted during HAProxy startup
12817 - MINOR: cli: Add "show startup-logs" command
12818 - MINOR: startup: Extend the scope the MODE_STARTING flag
12819 - MINOR: threads: Prepare makefile to link with pthread
12820 - MINOR: threads: Add THREAD_LOCAL macro
12821 - MINOR: threads: Add atomic-ops and plock includes in import dir
12822 - MEDIUM: threads: Add hathreads header file
12823 - MINOR: threads: Add mechanism to register per-thread init/deinit functions
12824 - MINOR: threads: Add nbthread parameter
12825 - MEDIUM: threads: Adds a set of functions to handle sync-point
12826 - MAJOR: threads: Start threads to experiment multithreading
12827 - MINOR: threads: Define the sync-point inside run_poll_loop
12828 - MEDIUM: threads/buffers: Define and register per-thread init/deinit functions
12829 - MEDIUM: threads/chunks: Transform trash chunks in thread-local variables
12830 - MEDIUM: threads/time: Many global variables from time.h are now thread-local
12831 - MEDIUM: threads/logs: Make logs thread-safe
12832 - MEDIUM: threads/pool: Make pool thread-safe by locking all access to a pool
12833 - MAJOR: threads/fd: Make fd stuffs thread-safe
12834 - MINOR: threads/fd: Add a mask of threads allowed to process on each fd in fdtab array
12835 - MEDIUM: threads/fd: Initialize the process mask during the call to fd_insert
12836 - MINOR: threads/fd: Process cached events of FDs depending on the process mask
12837 - MINOR: threads/polling: pollers now handle FDs depending on the process mask
12838 - WIP: SQUASH WITH SYNC POINT
12839 - MAJOR: threads/task: handle multithread on task scheduler
12840 - MEDIUM: threads/signal: Add a lock to make signals thread-safe
12841 - MEDIUM: threads/listeners: Make listeners thread-safe
12842 - MEDIUM: threads/proxy: Add a lock per proxy and atomically update proxy vars
12843 - MEDIUM: threads/server: Make connection list (priv/idle/safe) thread-safe
12844 - MEDIUM: threads/server: Add a lock per server and atomically update server vars
12845 - MINOR: threads/server: Add a lock to deal with insert in updates_servers list
12846 - MEDIUM: threads/lb: Make LB algorithms (lb_*.c) thread-safe
12847 - MEDIUM: threads/stick-tables: handle multithreads on stick tables
12848 - MINOR: threads/sample: Change temp_smp into a thread local variable
12849 - MEDIUM: threads/http: Make http_capture_bad_message thread-safe
12850 - MINOR: threads/regex: Change Regex trash buffer into a thread local variable
12851 - MAJOR: threads/applet: Handle multithreading for applets
12852 - MAJOR: threads/peers: Make peers thread safe
12853 - MAJOR: threads/buffer: Make buffer wait queue thread safe
12854 - MEDIUM: threads/stream: Make streams list thread safe
12855 - MAJOR: threads/ssl: Make SSL part thread-safe
12856 - MEDIUM: threads/queue: Make queues thread-safe
12857 - MAJOR: threads/map: Make acls/maps thread safe
12858 - MEDIUM: threads/freq_ctr: Make the frequency counters thread-safe
12859 - MEDIUM: thread/vars: Make vars thread-safe
12860 - MEDIUM: threads/filters: Add init/deinit callback per thread
12861 - MINOR: threads/filters: Update trace filter to add _per_thread callbacks
12862 - MEDIUM: threads/compression: Make HTTP compression thread-safe
12863 - MEDIUM: threads/lua: Makes the jmpbuf and some other buffers local to the current thread.
12864 - MEDIUM: threads/lua: Add locks around the Lua execution parts.
12865 - MEDIUM: threads/lua: Ensure that the launched tasks runs on the same threads than me
12866 - MEDIUM: threads/lua: Cannot acces to the socket if we try to access from another thread.
12867 - MEDIUM: threads/xref: Convert xref function to a thread safe model
12868 - MEDIUM: threads/tasks: Add lock around notifications
12869 - MEDIUM: thread/spoe: Make the SPOE thread-safe
12870 - MEDIUM: thread/dns: Make DNS thread-safe
12871 - MINOR: threads: Add thread-map config parameter in the global section
12872 - MINOR: threads/checks: Add a lock to protect the pid list used by external checks
12873 - MINOR: threads/checks: Set the task process_mask when a check is executed
12874 - MINOR: threads/mailers: Add a lock to protect queues of email alerts
12875 - MEDIUM: threads/server: Use the server lock to protect health check and cli concurrency
12876 - MINOR: threads: Don't start when device a detection module is used
12877 - BUG/MEDIUM: threads: Run the poll loop on the main thread too
12878 - BUG/MINOR: threads: Add missing THREAD_LOCAL on static here and there
12879 - MAJOR: threads: Offically enable the threads support in HAProxy
12880 - BUG/MAJOR: threads/freq_ctr: fix lock on freq counters.
12881 - BUG/MAJOR: threads/time: Store the time deviation in an 64-bits integer
12882 - BUILD: stick-tables: silence an uninitialized variable warning
12883 - BUG/MINOR: dns: Fix SRV records with the new thread code.
12884 - MINOR: ssl: Remove the global allow-0rtt option.
12885 - CLEANUP: threads: replace the last few 1UL<<tid with tid_bit
12886 - CLEANUP: threads: rename process_mask to thread_mask
12887 - MINOR: h1: add a function to measure the trailers length
12888 - MINOR: threads: add a portable barrier for threads and non-threads
12889 - BUG/MAJOR: threads/freq_ctr: use a memory barrier to detect changes
12890 - BUG/MEDIUM: threads: Initialize the sync-point
12891 - MEDIUM: connection: start to introduce a mux layer between xprt and data
12892 - MINOR: connection: implement alpn registration of muxes
12893 - MINOR: mux: register the pass-through mux for any ALPN string
12894 - MEDIUM: session: use the ALPN token and proxy mode to select the mux
12895 - MINOR: connection: report the major HTTP version from the MUX for logging (fc_http_major)
12896 - MINOR: connection: introduce conn_stream
12897 - MINOR: mux: add more methods to mux_ops
12898 - MINOR: connection: introduce the conn_stream manipulation functions
12899 - MINOR: mux_pt: implement remaining mux_ops methods
12900 - MAJOR: connection : Split struct connection into struct connection and struct conn_stream.
12901 - MINOR: connection: make conn_stream users also check for per-stream error flag
12902 - MINOR: conn_stream: new shutr/w status flags
12903 - MINOR: conn_stream: modify cs_shut{r,w} API to pass the desired mode
12904 - MEDIUM: connection: make conn_sock_shutw() aware of lingering
12905 - MINOR: connection: add cs_close() to close a conn_stream
12906 - MEDIUM: mux_pt: make cs_shutr() / cs_shutw() properly close the connection
12907 - MEDIUM: connection: replace conn_full_close() with cs_close()
12908 - MEDIUM: connection: make mux->detach() release the connection
12909 - MEDIUM: stream: do not forcefully close the client connection anymore
12910 - MEDIUM: checks: exclusively use cs_destroy() to release a connection
12911 - MEDIUM: connection: add a destroy callback
12912 - MINOR: session: release the listener with the session, not the stream
12913 - MEDIUM: session: make use of the connection's destroy callback
12914 - CONTRIB: hpack: implement a reverse huffman table generator for hpack
12915 - MINOR: hpack: implement the HPACK Huffman table decoder
12916 - MINOR: hpack: implement the header tables management
12917 - MINOR: hpack: implement the decoder
12918 - MEDIUM: hpack: implement basic hpack encoding
12919 - MINOR: h2: centralize all HTTP/2 protocol elements and constants
12920 - MINOR: h2: create a very minimalistic h2 mux
12921 - MINOR: h2: expose tune.h2.header-table-size to configure the table size
12922 - MINOR: h2: expose tune.h2.initial-window-size to configure the window size
12923 - MINOR: h2: expose tune.h2.max-concurrent-streams to limit the number of streams
12924 - MINOR: h2: create the h2c struct and allocate its pool
12925 - MINOR: h2: create the h2s struct and the associated pool
12926 - MINOR: h2: handle two extra stream states for errors
12927 - MINOR: h2: add a frame header descriptor for incoming frames
12928 - MEDIUM: h2: allocate and release the h2c context on connection init/end
12929 - MEDIUM: h2: implement basic recv/send/wake functions
12930 - MEDIUM: h2: dynamically allocate the demux buffer on Rx
12931 - MEDIUM: h2: implement the mux buffer allocator
12932 - MINOR: h2: add the connection and stream flags listing the causes for blocking
12933 - MINOR: h2: add function h2s_id() to report a stream's ID
12934 - MINOR: h2: small function to know when the mux is busy
12935 - MINOR: h2: new function h2c_error to mark an error on the connection
12936 - MINOR: h2: new function h2s_error() to mark an error on a stream
12937 - MINOR: h2: add h2_set_frame_size() to update the size in a binary frame
12938 - MINOR: h2: new function h2_peek_frame_hdr() to retrieve a new frame header
12939 - MINOR: h2: add a few functions to retrieve contents from a wrapping buffer
12940 - MINOR: h2: add stream lookup function based on the stream ID
12941 - MINOR: h2: create dummy idle and closed streams
12942 - MINOR: h2: add the function to create a new stream
12943 - MINOR: h2: update the {MUX,DEM}_{M,D}ALLOC flags on buffer availability
12944 - MEDIUM: h2: start to consider the H2_CF_{MUX,DEM}_* flags for polling
12945 - MINOR: h2: also terminate the connection on shutr
12946 - MEDIUM: h2: properly consider all conditions for end of connection
12947 - MEDIUM: h2: wake the connection up for send on pending streams
12948 - MEDIUM: h2: start to implement the frames processing loop
12949 - MINOR: h2: add a function to send a GOAWAY error frame
12950 - MINOR: h2: match the H2 connection preface on init
12951 - MEDIUM: h2: enable connection polling for send when a cs wants to emit
12952 - MEDIUM: h2: enable reading again on the connection if it was blocked on stream buffer full
12953 - MEDIUM: h2: process streams pending for sending
12954 - MINOR: h2: send a real SETTINGS frame based on the configuration
12955 - MEDIUM: h2: detect the presence of the first settings frame
12956 - MINOR: h2: create a stream parser for the demuxer
12957 - MINOR: h2: implement PING frames
12958 - MEDIUM: h2: decode SETTINGS frames and extract relevant settings
12959 - MINOR: h2: lookup the stream during demuxing
12960 - MEDIUM: h2: honor WINDOW_UPDATE frames
12961 - MINOR: h2: implement h2_send_rst_stream() to send RST_STREAM frames
12962 - MINOR: h2: handle CONTINUATION frames
12963 - MEDIUM: h2: partial implementation of h2_detach()
12964 - MEDIUM: h2: unblock a connection when its current stream detaches
12965 - MEDIUM: h2: basic processing of HEADERS frame
12966 - MEDIUM: h2: don't use trash to decode headers!
12967 - MEDIUM: h2: implement the response HEADERS frame to encode the H1 response
12968 - MEDIUM: h2: send the H1 response body as DATA frames
12969 - MEDIUM: h2: skip the response trailers if any
12970 - MEDIUM: h2: properly continue to parse header block when facing a 1xx response
12971 - MEDIUM: h2: send WINDOW_UPDATE frames for connection
12972 - MEDIUM: h2: handle request body in DATA frames
12973 - MINOR: h2: handle RST_STREAM frames
12974 - MEDIUM: h2: send DATA+ES or RST_STREAM on shutw/shutr
12975 - MINOR: h2: use a common function to signal some and all streams.
12976 - MEDIUM: h2: handle GOAWAY frames
12977 - MINOR: h2: centralize the check for the idle streams
12978 - MINOR: h2: centralize the check for the half-closed(remote) streams
12979 - MEDIUM: h2: silently ignore frames higher than last_id after GOAWAY
12980 - MINOR: h2: properly reject PUSH_PROMISE frames coming from the client
12981 - MEDIUM: h2: perform a graceful shutdown on "Connection: close"
12982 - MEDIUM: h2: send a GOAWAY frame when dealing with an empty response
12983 - MEDIUM: h2: apply a timeout to h2 connections
12984 - BUG/MEDIUM: h2: fix incorrect timeout handling on the connection
12985 - MEDIUM: shctx: forbid shctx to read more than expected
12986 - MEDIUM: cache: configuration parsing and initialization
12987 - MEDIUM: cache: store objects in cache
12988 - MEDIUM: cache: deliver objects from cache
12989
Willy Tarreauf08137c2017-10-22 10:13:45 +0200129902017/10/22 : 1.8-dev3
12991 - REORG: ssl: move defines and methodVersions table upper
12992 - MEDIUM: ssl: ctx_set_version/ssl_set_version func for methodVersions table
12993 - MINOR: ssl: support ssl-min-ver and ssl-max-ver with crt-list
12994 - MEDIUM: ssl: disable SSLv3 per default for bind
12995 - BUG/MAJOR: ssl: fix segfault on connection close using async engines.
12996 - BUG/MAJOR: ssl: buffer overflow using offloaded ciphering on async engine
12997 - BUG/MINOR: ssl: do not call directly the conn_fd_handler from async_fd_handler
12998 - BUG/MINOR: haproxy/cli : fix for solaris/illumos distros for CMSG* macros
12999 - BUG/MEDIUM: build without openssl broken
13000 - BUG/MINOR: warning: need_resend may be used uninitialized
13001 - BUG/MEDIUM: misplaced exit and wrong exit code
13002 - BUG/MINOR: Makefile: fix compile error with USE_LUA=1 in ubuntu16.04
13003 - BUILD: scripts: make publish-release support bare repositories
13004 - BUILD: scripts: add an automatic mode for publish-release
13005 - BUILD: scripts: add a "quiet" mode to publish-release
13006 - BUG/MAJOR: http: call manage_client_side_cookies() before erasing the buffer
13007 - BUG/MINOR: buffers: Fix bi/bo_contig_space to handle full buffers
13008 - CONTRIB: plug qdiscs: Plug queuing disciplines mini HOWTO.
13009 - BUG/MINOR: acls: Set the right refflag when patterns are loaded from a map
13010 - BUG/MINOR: ssl: Be sure that SSLv3 connection methods exist for openssl < 1.1.0
13011 - BUG/MINOR: http/filters: Be sure to wait if a filter loops in HTTP_MSG_ENDING
13012 - BUG/MEDIUM: peers: Peers CLOSE_WAIT issue.
13013 - BUG/MAJOR: server: Segfault after parsing server state file.
13014 - BUG/MEDIUM: unix: never unlink a unix socket from the file system
13015 - scripts: create-release pass -n to tail
13016 - SCRIPTS: create-release: enforce GIT_COMMITTER_{NAME|EMAIL} validity
13017 - BUG/MEDIUM: fix segfault when no argument to -x option
13018 - MINOR: warning on multiple -x
13019 - MINOR: mworker: don't copy -x argument anymore in copy_argv()
13020 - BUG/MEDIUM: mworker: don't reuse PIDs passed to the master
13021 - BUG/MINOR: Wrong peer task expiration handling during synchronization processing.
13022 - BUG/MINOR: cfgparse: Check if tune.http.maxhdr is in the range 1..32767
13023 - BUG/MINOR: log: pin the front connection when front ip/ports are logged
13024 - DOC: fix references to the section about the unix socket
13025 - BUG/MINOR: stream: flag TASK_WOKEN_RES not set if task in runqueue
13026 - MAJOR: task: task scheduler rework.
13027 - MINOR: task/stream: tasks related to a stream must be init by the caller.
13028 - MINOR: queue: Change pendconn_get_next_strm into private function
13029 - MINOR: backends: Change get_server_sh/get_server_uh into private function
13030 - MINOR: queue: Change pendconn_from_srv/pendconn_from_px into private functions
13031 - MEDIUM: stream: make stream_new() always set the target and analysers
13032 - MINOR: frontend: initialize HTTP layer after the debugging code
13033 - MINOR: connection: add a .get_alpn() method to xprt_ops
13034 - MINOR: ssl: add a get_alpn() method to ssl_sock
13035 - MINOR: frontend: retrieve the ALPN name when available
13036 - MINOR: frontend: report the connection's ALPN in the debug output
13037 - MINOR: stream: don't set backend's nor response analysers on SF_TUNNEL
13038 - MINOR: connection: send data before receiving
13039 - MAJOR: applet: applet scheduler rework.
13040 - BUG/MAJOR: frontend: don't dereference a null conn on outgoing connections
13041 - BUG/MAJOR: cli: fix custom io_release was crushed by NULL.
13042 - BUG/MAJOR: map: fix segfault during 'show map/acl' on cli.
13043 - BUG/MAJOR: compression: Be sure to release the compression state in all cases
13044 - MINOR: compression: Use a memory pool to allocate compression states
13045 - BUG/MAJOR: applet: fix a freeze if data is immedately forwarded.
13046 - DOC: fix references to the section about time format.
13047 - BUG/MEDIUM: map/acl: fix unwanted flags inheritance.
13048 - BUG/MAJOR: http: fix buffer overflow on loguri buffer.
13049 - MINOR: ssl: compare server certificate names to the SNI on outgoing connections
13050 - BUG/MINOR: stream: Don't forget to remove CF_WAKE_ONCE flag on response channel
13051 - BUG/MINOR: http: Don't reset the transaction if there are still data to send
13052 - BUG/MEDIUM: filters: Be sure to call flt_end_analyze for both channels
13053 - MINOR: peers: Add additional information to stick-table definition messages.
13054 - BUG/MINOR: http: properly handle all 1xx informational responses
13055 - OPTIM: ssl: don't consider a small ssl_read() as an indication of end of buffer
13056 - BUG/MINOR: peers: peer synchronization issue (with several peers sections).
13057 - CLEANUP: hdr_idx: make some function arguments const where possible
13058 - BUG/MINOR: Prevent a use-after-free on error scenario on option "-x".
13059 - BUG/MINOR: lua: In error case, the safe mode is not removed
13060 - BUG/MINOR: lua: executes the function destroying the Lua session in safe mode
13061 - BUG/MAJOR: lua/socket: resources not detroyed when the socket is aborted
13062 - BUG/MEDIUM: lua: bad memory access
13063 - BUG/MINOR: Lua: variable already initialized
13064 - DOC: update CONTRIBUTING regarding optional parts and message format
13065 - DOC: update the list of OpenSSL versions in the README
13066 - BUG/MINOR: http: Set the response error state in http_sync_res_state
13067 - MINOR: http: Reorder/rewrite checks in http_resync_states
13068 - MINOR: http: Switch requests/responses in TUNNEL mode only by checking txn flags
13069 - BUG/MEDIUM: http: Switch HTTP responses in TUNNEL mode when body length is undefined
13070 - MINOR: http: Rely on analyzers mask to end processing in forward_body functions
13071 - BUG/MINOR: http: Fix bug introduced in previous patch in http_resync_states
13072 - BUG/MINOR: contrib/modsecurity: BSD build fix
13073 - BUG/MINOR: contrib/mod_defender: build fix
13074 - BUG/MINOR: ssl: remove haproxy SSLv3 support when ssl lib have no SSLv3
13075 - MINOR: ssl: remove an unecessary SSL_OP_NO_* dependancy
13076 - BUILD: ssl: fix compatibility with openssl without TLSEXT_signature_*
13077 - MINOR: tools: add a portable timegm() alternative
13078 - BUILD: lua: replace timegm() with my_timegm() to fix build on Solaris 10
13079 - DOC: Updated 51Degrees git URL to point to a stable version.
13080 - BUG/MAJOR: http: Fix possible infinity loop in http_sync_(req|res)_state
13081 - MINOR: memory: remove macros
13082 - BUG/MINOR: lua: Fix Server.get_addr() port values
13083 - BUG/MINOR: lua: Correctly use INET6_ADDRSTRLEN in Server.get_addr()
13084 - MINOR: samples: Handle the type SMP_T_METH when we duplicate a sample in smp_dup
13085 - MINOR: samples: Handle the type SMP_T_METH in smp_is_safe and smp_is_rw
13086 - MINOR: samples: Don't allocate memory for SMP_T_METH sample when method is known
13087 - BUG/MINOR: lua: always detach the tcp/http tasks before freeing them
13088 - MINOR: task: always preinitialize the task's timeout in task_init()
13089 - CLEANUP: task: remove all initializations to TICK_ETERNITY after task_new()
13090 - BUG/MAJOR: lua: properly dequeue hlua_applet_wakeup() for new scheduler
13091 - MINOR: lua: Add proxy as member of proxy object.
13092 - DOC: lua: Proxy class doc update
13093 - MINOR: lua: Add lists of frontends and backends
13094 - BUG/MINOR: ssl: Fix check against SNI during server certificate verification
13095 - BUG/MINOR: ssl: make use of the name in SNI before verifyhost
13096 - MINOR: ssl: add a new error codes for wrong server certificates
13097 - BUG/MEDIUM: stream: don't retry SSL connections which fail the SNI name check
13098 - MINOR: ssl: add "no-ca-names" parameter for bind
13099 - BUG/MINOR: lua: Fix bitwise logic for hlua_server_check_* functions.
13100 - DOC: fix alphabetical order of "show commands" in management.txt
13101 - MINOR: listener: add a function to return a listener's state as a string
13102 - MINOR: cli: add a new "show fd" command
13103 - BUG/MEDIUM: ssl: Fix regression about certificates generation
13104 - MINOR: Add server port field to server state file.
13105 - MINOR: ssl: allow to start without certificate if strict-sni is set
13106 - MINOR: dns: Cache previous DNS answers.
13107 - MINOR: obj: Add a new type of object, OBJ_TYPE_SRVRQ.
13108 - Add a few functions to do unaligned access.
13109 - MINOR: dns: Handle SRV records.
13110 - MINOR: check: Fix checks when using SRV records.
13111 - MINOR: doc: Document SRV label usage.
13112 - BUILD/MINOR: cli: shut a minor gcc warning in "show fd"
13113 - BUILD: ssl: replace SSL_CTX_get0_privatekey for openssl < 1.0.2
13114 - BUILD/MINOR: build without openssl still broken
13115 - BUG/MAJOR: stream: in stream_free(), close the front endpoint and not the origin
13116 - CLEANUP: raw_sock: Use a better name for the constructor than __ssl_sock_deinit()
13117 - MINOR: init: Fix CPU affinity setting on FreeBSD.
13118 - MINOR: dns: Update analysis of TRUNCATED response for SRV records
13119 - MINOR: dns: update record dname matching for SRV query types
13120 - MINOR: dns: update dns response buffer reading pointer due to SRV record
13121 - MINOR: dns: duplicate entries in resolution wait queue for SRV records
13122 - MINOR: dns: make debugging function dump_dns_config() compatible with SRV records
13123 - MINOR: dns: ability to use a SRV resolution for multiple backends
13124 - MINOR: dns: enable caching of responses for server set by a SRV record
13125 - MINOR: dns: new dns record type (RTYPE) for OPT
13126 - MINOR: dns: enabled edns0 extension and make accpeted payload size tunable
13127 - MINOR: dns: default "hold obsolete" timeout set to 0
13128 - MINOR: chunks: add chunk_memcpy() and chunk_memcat()
13129 - MINOR: session: add a streams field to the session struct
13130 - MINOR: stream: link the stream to its session
13131 - MEDIUM: session: do not free a session until no stream references it
13132 - MINOR: ist: implement very simple indirect strings
13133 - TESTS: ist: add a test file for the functions
13134 - MINOR: http: export some of the HTTP parser macros
13135 - BUG/MINOR: Wrong type used as argument for spoe_decode_buffer().
13136 - BUG/MINOR: dns: server set by SRV records stay in "no resolution" status
13137 - MINOR: dns: Maximum DNS udp payload set to 8192
13138 - MINOR: dns: automatic reduction of DNS accpeted payload size
13139 - MINOR: dns: make SRV record processing more verbose
13140 - CLEANUP: dns: remove duplicated code in dns_resolve_recv()
13141 - CLEANUP: dns: remove duplicated code in dns_validate_dns_response()
13142 - BUG/MINOR: dns: wrong resolution interval lead to 100% CPU
13143 - BUG/MEDIUM: dns: fix accepted_payload_size parser to avoid integer overflow
13144 - BUG/MAJOR: lua: fix the impact of the scheduler changes again
13145 - BUG/MEDIUM: lua: HTTP services must take care of body-less status codes
13146 - MINOR: lua: properly process the contents of the content-length field
13147 - BUG/MEDIUM: stream: properly set the required HTTP analysers on use-service
13148 - OPTIM: lua: don't use expensive functions to parse headers in the HTTP applet
13149 - OPTIM: lua: don't add "Connection: close" on the response
13150 - REORG/MEDIUM: connection: introduce the notion of connection handle
13151 - BUG/MINOR: stream-int: don't check the CO_FL_CURR_WR_ENA flag
13152 - MEDIUM: connection: get rid of data->init() which was not for data
13153 - MEDIUM: stream: make stream_new() allocate its own task
13154 - CLEANUP: listener: remove the unused handler field
13155 - MEDIUM: session: add a pointer to a struct task in the session
13156 - MINOR: stream: provide a new stream creation function for connections
13157 - MEDIUM: connection: remove useless flag CO_FL_DATA_RD_SH
13158 - CLEANUP: connection: remove the unused conn_sock_shutw_pending()
13159 - MEDIUM: connection: remove useless flag CO_FL_DATA_WR_SH
13160 - DOC: add CLI info on privilege levels
13161 - DOC: Refer to Mozilla TLS info / config generator
13162 - MINOR: ssl: remove duplicate ssl_methods in struct bind_conf
13163 - BUG/MEDIUM: http: Fix a regression bug when a HTTP response is in TUNNEL mode
13164 - DOC: Add note about "* " prefix in CSV stats
13165 - CLEANUP: memory: Remove unused function pool_destroy
13166 - MINOR: listeners: Change listener_full and limit_listener into private functions
13167 - MINOR: listeners: Change enable_listener and disable_listener into private functions
13168 - MINOR: fd: Don't forget to reset fdtab[fd].update when a fd is added/removed
13169 - MINOR: fd: Set owner and iocb field before inserting a new fd in the fdtab
13170 - MINOR: backends: Make get_server_* functions explicitly static
13171 - MINOR: applet: Check applets_active_queue before processing applets queue
13172 - MINOR: chunks: Use dedicated function to init/deinit trash buffers
13173 - MEDIUM: chunks: Realloc trash buffers only after the config is parsed and checked
13174 - MINOR: logs: Use dedicated function to init/deinit log buffers
13175 - MINOR: logs: Realloc log buffers only after the config is parsed and checked
13176 - MINOR: buffers: Move swap_buffer into buffer.c and add deinit_buffer function
13177 - MINOR: stick-tables: Make static_table_key a struct variable instead of a pointer
13178 - MINOR: http: Use a trash chunk to store decoded string of the HTTP auth header
13179 - MINOR: fd: Add fd_active function
13180 - MINOR: fd: Use inlined functions to check fd state in fd_*_send/recv functions
13181 - MINOR: fd: Move (de)allocation of fdtab and fdinfo in (de)init_pollers
13182 - MINOR: freq_ctr: Return the new value after an update
13183 - MEDIUM: check: server states and weight propagation re-work
13184 - BUG/MEDIUM: epoll: ensure we always consider HUP and ERR
13185 - MINOR: fd: Add fd_update_events function
13186 - MINOR: polling: Use fd_update_events to update events seen for a fd
13187 - BUG/MINOR: server: Remove FQDN requirement for using init-addr and state file
13188 - Revert "BUG/MINOR: server: Remove FQDN requirement for using init-addr and state file"
13189 - MINOR: ssl: rework smp_fetch_ssl_fc_cl_str without internal ssl use
13190 - BUG/MEDIUM: http: Close streams for connections closed before a redirect
13191 - BUG/MINOR: Lua: The socket may be destroyed when we try to access.
13192 - MINOR: xref: Add a new xref system
13193 - MEDIUM: xref/lua: Use xref for referencing cosocket relation between stream and lua
13194 - MINOR: tasks: Move Lua notification from Lua to tasks
13195 - MINOR: net_helper: Inline functions meant to be inlined.
13196 - MINOR: cli: add socket commands and config to prepend informational messages with severity
13197 - MINOR: add severity information to cli feedback messages
13198 - BUILD: Makefile: add a function to detect support by the compiler of certain options
13199 - BUILD: Makefile: shut certain gcc/clang stupid warnings
13200 - BUILD: Makefile: improve detection of support for compiler warnings
13201 - MINOR: peers: don't reference the incoming listener on outgoing connections
13202 - MINOR: frontend: don't retrieve ALPN on the critical path
13203 - MINOR: protocols: always pass a "port" argument to the listener creation
13204 - MINOR: protocols: register the ->add function and stop calling them directly
13205 - MINOR: unix: remove the now unused proto_uxst.h file
13206 - MINOR: listeners: new function create_listeners
13207 - MINOR: listeners: make listeners count consistent with reality
13208 - MEDIUM: session: take care of incrementing/decrementing jobs
13209 - MINOR: listener: new function listener_release
13210 - MINOR: session: small cleanup of conn_complete_session()
13211 - MEDIUM: session: factor out duplicated code for conn_complete_session
13212 - MEDIUM: session: count the frontend's connections at a single place
13213 - BUG/MEDIUM: compression: Fix check on txn in smp_fetch_res_comp_algo
13214 - BUG/MINOR: compression: Check response headers before http-response rules eval
13215 - BUG/MINOR: spoe: Don't rely on SPOE ctx in debug message when its creation failed
13216 - BUG/MINOR: dns: Fix check on nameserver in snr_resolution_cb
13217 - MINOR: ssl: Remove useless checks on bind_conf or bind_conf->is_ssl
13218 - BUG/MINOR: contrib/mod_defender: close the va_list argp before return
13219 - BUG/MINOR: contrib/modsecurity: close the va_list ap before return
13220 - MINOR: tools: make my_htonll() more efficient on x86_64
13221 - MINOR: buffer: add b_del() to delete a number of characters
13222 - MINOR: buffer: add b_end() and b_to_end()
13223 - MINOR: net_helper: add functions to read from vectors
13224 - MINOR: net_helper: add write functions
13225 - MINOR: net_helper: add 64-bit read/write functions
13226 - MINOR: connection: adjust CO_FL_NOTIFY_DATA after removal of flags
13227 - MINOR: ist: add a macro to ease const array initialization
13228 - BUG/MEDIUM: server: unwanted behavior leaving maintenance mode on tracked stopping server
13229 - BUG/MEDIUM: server: unwanted behavior leaving maintenance mode on tracked stopping server (take2)
13230 - BUG/MINOR: log: fixing small memory leak in error code path.
13231 - BUG/MINOR: contrib/halog: fixing small memory leak
13232 - BUG/MEDIUM: tcp/http: set-dst-port action broken
13233 - CLEANUUP: checks: don't set conn->handle.fd to -1
13234 - BUG/MEDIUM: tcp-check: properly indicate polling state before performing I/O
13235 - BUG/MINOR: tcp-check: don't quit with pending data in the send buffer
13236 - BUG/MEDIUM: tcp-check: don't call tcpcheck_main() from the I/O handlers!
13237 - BUG/MINOR: unix: properly check for octal digits in the "mode" argument
13238 - MINOR: checks: make chk_report_conn_err() take a check, not a connection
13239 - CLEANUP: checks: remove misleading comments and statuses for external process
13240 - CLEANUP: checks: don't report report the fork() error twice
13241 - CLEANUP: checks: do not allocate a connection for process checks
13242 - TESTS: checks: add a simple test config for external checks
13243 - BUG/MINOR: tcp-check: don't initialize then break a connection starting with a comment
13244 - TESTS: checks: add a simple test config for tcp-checks
13245 - MINOR: tcp-check: make tcpcheck_main() take a check, not a connection
13246 - MINOR: checks: don't create then kill a dummy connection before tcp-checks
13247 - MEDIUM: checks: make tcpcheck_main() indicate if it recycled a connection
13248 - MEDIUM: checks: do not allocate a permanent connection anymore
13249 - BUG/MEDIUM: cli: fix "show fd" crash when dumping closed FDs
13250 - BUG/MEDIUM: http: Return an error when url_dec sample converter failed
13251 - BUG/MAJOR: stream-int: don't re-arm recv if send fails
13252 - BUILD/MINOR: 51d: fix warning when building with 51Degrees release version 3.2.12.12
13253 - DOC: 51d: add 51Degrees git URL that points to release version 3.2.12.12
13254 - DOC: 51d: Updated git URL and instructions for getting Hash Trie data files.
13255 - MINOR: compiler: restore the likely() wrapper for gcc 5.x
13256 - MINOR: session: remove the list of streams from struct session
13257 - DOC: fix some typos
13258 - MINOR: server: add the srv_queue() sample fetch method
13259 - MINOR: payload: add new sample fetch functions to process distcc protocol
13260 - MAJOR: servers: propagate server status changes asynchronously.
13261 - BUG/MEDIUM: ssl: fix OCSP expiry calculation
13262 - BUG/MINOR: stream-int: don't set MSG_MORE on SHUTW_NOW without AUTO_CLOSE
13263 - MINOR: server: Handle weight increase in consistent hash.
13264 - MINOR: checks: Add a new keyword to specify a SNI when doing SSL checks.
13265 - BUG/MINOR: tools: fix my_htonll() on x86_64
13266 - BUG/MINOR: stats: Clear a bit more counters with in cli_parse_clear_counters().
13267 - BUG/MAJOR: lua: scheduled task is freezing.
13268 - MINOR: buffer: add bo_del() to delete a number of characters from output
13269 - MINOR: buffer: add a function to match against string patterns
13270 - MINOR: buffer: add two functions to inject data into buffers
13271 - MINOR: buffer: add buffer_space_wraps()
13272 - REORG: channel: finally rename the last bi_* / bo_* functions
13273 - MINOR: buffer: add bo_getblk() and bo_getblk_nc()
13274 - MINOR: channel: make use of bo_getblk{,_nc} for their channel equivalents
13275 - MINOR: channel: make the channel be a const in all {ci,co}_get* functions
13276 - MINOR: ist: add ist0() to add a trailing zero to a string.
13277 - BUG/MEDIUM: log: check result details truncated.
13278 - MINOR: buffer: make bo_getblk_nc() not return 2 for a full buffer
13279 - REORG: http: move some very http1-specific parts to h1.{c,h}
13280 - REORG: http: move the HTTP/1 chunk parser to h1.{c,h}
13281 - REORG: http: move the HTTP/1 header block parser to h1.c
13282 - MEDIUM: http: make the chunk size parser only depend on the buffer
13283 - MEDIUM: http: make the chunk crlf parser only depend on the buffer
13284 - MINOR: h1: add struct h1m for basic HTTP/1 messages
13285 - MINOR: http: add very simple header management based on double strings
13286 - MEDIUM: h1: reimplement the http/1 response parser for the gateway
13287 - REORG: connection: rename CO_FL_DATA_* -> CO_FL_XPRT_*
13288 - MEDIUM: connection: make conn_sock_shutw() aware of lingering
13289 - MINOR: connection: ensure conn_ctrl_close() also resets the fd
13290 - MINOR: connection: add conn_stop_tracking() to disable tracking
13291 - MINOR: tcp: use conn_full_close() instead of conn_force_close()
13292 - MINOR: unix: use conn_full_close() instead of conn_force_close()
13293 - MINOR: checks: use conn_full_close() instead of conn_force_close()
13294 - MINOR: session: use conn_full_close() instead of conn_force_close()
13295 - MINOR: stream: use conn_full_close() instead of conn_force_close()
13296 - MINOR: stream: use conn_full_close() instead of conn_force_close()
13297 - MINOR: backend: use conn_full_close() instead of conn_force_close()
13298 - MINOR: stream-int: use conn_full_close() instead of conn_force_close()
13299 - MINOR: connection: remove conn_force_close()
13300 - BUG/MINOR: ssl: ocsp response with 'revoked' status is correct
13301
Willy Tarreauf57a29a2017-06-02 15:59:51 +0200133022017/06/02 : 1.8-dev2
13303 - CLEANUP: server: moving netinet/tcp.h inclusion
13304 - DOC: changed "block"(deprecated) examples to http-request deny
13305 - DOC: add few comments to examples.
13306 - DOC: update sample code for PROXY protocol
13307 - DOC: mention lighttpd 1.4.46 implements PROXY
13308 - MINOR server: Restrict dynamic cookie check to the same proxy.
13309 - DOC: stick-table is available in frontend sections
13310 - BUG/MINOR: server : no transparent proxy for DragonflyBSD
13311 - BUILD/MINOR: stats: remove unexpected argument to stats_dump_json_header()
13312 - BUILD/MINOR: tools: fix build warning in debug_hexdump()
13313 - BUG/MINOR: dns: Wrong address family used when creating IPv6 sockets.
13314 - BUG/MINOR: config: missing goto out after parsing an incorrect ACL character
13315 - BUG/MINOR: arg: don't try to add an argument on failed memory allocation
13316 - MEDIUM: server: Inherit CLI weight changes and agent-check weight responses
13317 - BUG/MEDIUM: arg: ensure that we properly unlink unresolved arguments on error
13318 - BUG/MEDIUM: acl: don't free unresolved args in prune_acl_expr()
13319 - BUG/MEDIUM: servers: unbreak server weight propagation
13320 - MINOR: lua: ensure the memory allocator is used all the time
13321 - MINOR: cli: Add a command to send listening sockets.
13322 - MINOR: global: Add an option to get the old listening sockets.
13323 - MINOR: tcp: When binding socket, attempt to reuse one from the old proc.
13324 - MINOR: doc: document the -x flag
13325 - MINOR: proxy: Don't close FDs if not our proxy.
13326 - MINOR: socket transfer: Set a timeout on the socket.
13327 - MINOR: systemd wrapper: add support for passing the -x option.
13328 - BUG/MINOR: server: Fix a wrong error message during 'usesrc' keyword parsing.
13329 - BUG/MAJOR: Broken parsing for valid keywords provided after 'source' setting.
13330 - CLEANUP: logs: typo: simgle => single
13331 - BUG/MEDIUM: acl: proprely release unused args in prune_acl_expr()
13332 - MEDIUM: config: don't check config validity when there are fatal errors
13333 - BUG/MAJOR: Use -fwrapv.
13334 - BUG/MINOR: server: don't use "proxy" when px is really meant.
13335 - BUG/MEDIUM: http: Drop the connection establishment when a redirect is performed
13336 - BUG/MINOR: server: missing default server 'resolvers' setting duplication.
13337 - MINOR: server: Extract the code responsible of copying default-server settings.
13338 - MINOR: server: Extract the code which finalizes server initializations after 'server' lines parsing.
13339 - MINOR: server: Add 'server-template' new keyword supported in backend sections.
13340 - MINOR: server: Add server_template_init() function to initialize servers from a templates.
13341 - DOC: Add documentation for new "server-template" keyword.
13342 - DOC: add layer 4 links/cross reference to "block" keyword.
13343 - DOC: errloc/errorloc302/errorloc303 missing status codes.
13344 - BUG/MEDIUM: lua: memory leak
13345 - CLEANUP: lua: remove test
13346 - BUG/MINOR: hash-balance-factor isn't effective in certain circumstances
13347 - BUG/MINOR: change header-declared function to static inline
13348 - REORG: spoe: move spoe_encode_varint / spoe_decode_varint from spoe to common
13349 - MINOR: Add binary encoding request header sample fetch
13350 - MINOR: proto-http: Add sample fetch wich returns all HTTP headers
13351 - MINOR: Add ModSecurity wrapper as contrib
13352 - BUG/MINOR: ssl: fix warnings about methods for opensslv1.1.
13353 - DOC: update RFC references
13354 - CONTRIB: tcploop: add action "X" to execute a command
13355 - MINOR: server: cli: Add server FQDNs to server-state file and stats socket.
13356 - BUG/MINOR: contrib/mod_security: fix build on FreeBSD
13357 - BUG/MINOR: checks: don't send proxy protocol with agent checks
13358 - MINOR: ssl: add prefer-client-ciphers
13359 - MEDIUM: ssl: revert ssl/tls version settings relative to default-server.
13360 - MEDIUM: ssl: ssl_methods implementation is reworked and factored for min/max tlsxx
13361 - MEDIUM: ssl: calculate the real min/max TLS version and find holes
13362 - MINOR: ssl: support TLSv1.3 for bind and server
13363 - MINOR: ssl: show methods supported by openssl
13364 - MEDIUM: ssl: add ssl-min-ver and ssl-max-ver parameters for bind and server
13365 - MEDIUM: ssl: ssl-min-ver and ssl-max-ver compatibility.
13366 - CLEANUP: retire obsoleted USE_GETSOCKNAME build option
13367 - BUG/MAJOR: dns: Broken kqueue events handling (BSD systems).
13368 - MINOR: sample: Add b64dec sample converter
13369 - BUG/MEDIUM: lua: segfault if a converter or a sample doesn't return anything
13370 - MINOR: cli: add ACCESS_LVL_MASK to store the access level
13371 - MINOR: cli: add 'expose-fd listeners' to pass listeners FDs
13372 - MEDIUM: proxy: zombify proxies only when the expose-fd socket is bound
13373 - MEDIUM: ssl: add basic support for OpenSSL crypto engine
13374 - MAJOR: ssl: add openssl async mode support
13375 - MEDIUM: ssl: handle multiple async engines
13376 - MINOR: boringssl: basic support for OCSP Stapling
13377 - MEDIUM: mworker: replace systemd mode by master worker mode
13378 - MEDIUM: mworker: handle reload and signals
13379 - MEDIUM: mworker: wait mode on reload failure
13380 - MEDIUM: mworker: try to guess the next stats socket to use with -x
13381 - MEDIUM: mworker: exit-on-failure option
13382 - MEDIUM: mworker: workers exit when the master leaves
13383 - DOC: add documentation for the master-worker mode
13384 - MEDIUM: systemd: Type=forking in unit file
13385 - MAJOR: systemd-wrapper: get rid of the wrapper
13386 - MINOR: log: Add logurilen tunable.
13387 - CLEANUP: server.c: missing prototype of srv_free_dns_resolution
13388 - MINOR: dns: smallest DNS fqdn size
13389 - MINOR: dns: functions to manage memory for a DNS resolution structure
13390 - MINOR: dns: parse_server() now uses srv_alloc_dns_resolution()
13391 - REORG: dns: dns_option structure, storage of hostname_dn
13392 - MINOR: dns: new snr_check_ip_callback function
13393 - MAJOR: dns: save a copy of the DNS response in struct resolution
13394 - MINOR: dns: implement a LRU cache for DNS resolutions
13395 - MINOR: dns: make 'ancount' field to match the number of saved records
13396 - MINOR: dns: introduce roundrobin into the internal cache (WIP)
13397 - MAJOR/REORG: dns: DNS resolution task and requester queues
13398 - BUILD: ssl: fix build with OPENSSL_NO_ENGINE
13399 - MINOR: Add Mod Defender integration as contrib
13400 - CLEANUP: str2mask return code comment: non-zero -> zero.
13401 - MINOR: tools: make debug_hexdump() use a const char for the string
13402 - MINOR: tools: make debug_hexdump() take a string prefix
13403 - CLEANUP: connection: remove unused CO_FL_WAIT_DATA
13404
Willy Tarreau7b677262017-04-03 09:27:49 +0200134052017/04/03 : 1.8-dev1
13406 - BUG/MEDIUM: proxy: return "none" and "unknown" for unknown LB algos
13407 - BUG/MINOR: stats: make field_str() return an empty string on NULL
13408 - DOC: Spelling fixes
13409 - BUG/MEDIUM: http: Fix tunnel mode when the CONNECT method is used
13410 - BUG/MINOR: http: Keep the same behavior between 1.6 and 1.7 for tunneled txn
13411 - BUG/MINOR: filters: Protect args in macros HAS_DATA_FILTERS and IS_DATA_FILTER
13412 - BUG/MINOR: filters: Invert evaluation order of HTTP_XFER_BODY and XFER_DATA analyzers
13413 - BUG/MINOR: http: Call XFER_DATA analyzer when HTTP txn is switched in tunnel mode
13414 - BUG/MAJOR: stream: fix session abort on resource shortage
13415 - OPTIM: stream-int: don't disable polling anymore on DONT_READ
13416 - BUG/MINOR: cli: allow the backslash to be escaped on the CLI
13417 - BUG/MEDIUM: cli: fix "show stat resolvers" and "show tls-keys"
13418 - DOC: Fix map table's format
13419 - DOC: Added 51Degrees conv and fetch functions to documentation.
13420 - BUG/MINOR: http: don't send an extra CRLF after a Set-Cookie in a redirect
13421 - DOC: mention that req_tot is for both frontends and backends
13422 - BUG/MEDIUM: variables: some variable name can hide another ones
13423 - MINOR: lua: Allow argument for actions
13424 - BUILD: rearrange target files by build time
13425 - CLEANUP: hlua: just indent functions
13426 - MINOR: lua: give HAProxy variable access to the applets
13427 - BUG/MINOR: stats: fix be/sessions/max output in html stats
13428 - MINOR: proxy: Add fe_name/be_name fetchers next to existing fe_id/be_id
13429 - DOC: lua: Documentation about some entry missing
13430 - DOC: lua: Add documentation about variable manipulation from applet
13431 - MINOR: Do not forward the header "Expect: 100-continue" when the option http-buffer-request is set
13432 - DOC: Add undocumented argument of the trace filter
13433 - DOC: Fix some typo in SPOE documentation
13434 - MINOR: cli: Remove useless call to bi_putchk
13435 - BUG/MINOR: cli: be sure to always warn the cli applet when input buffer is full
13436 - MINOR: applet: Count number of (active) applets
13437 - MINOR: task: Rename run_queue and run_queue_cur counters
13438 - BUG/MEDIUM: stream: Save unprocessed events for a stream
13439 - BUG/MAJOR: Fix how the list of entities waiting for a buffer is handled
13440 - BUILD/MEDIUM: Fixing the build using LibreSSL
13441 - BUG/MEDIUM: lua: In some case, the return of sample-fetches is ignored (2)
13442 - SCRIPTS: git-show-backports: fix a harmless typo
13443 - SCRIPTS: git-show-backports: add -H to use the hash of the commit message
13444 - BUG/MINOR: stream-int: automatically release SI_FL_WAIT_DATA on SHUTW_NOW
13445 - CLEANUP: applet/lua: create a dedicated ->fcn entry in hlua_cli context
13446 - CLEANUP: applet/table: add an "action" entry in ->table context
13447 - CLEANUP: applet: remove the now unused appctx->private field
13448 - DOC: lua: documentation about time parser functions
13449 - DOC: lua: improve links
13450 - DOC: lua: section declared twice
13451 - MEDIUM: cli: 'show cli sockets' list the CLI sockets
13452 - BUG/MINOR: cli: "show cli sockets" wouldn't list all processes
13453 - BUG/MINOR: cli: "show cli sockets" would always report process 64
13454 - CLEANUP: lua: rename one of the lua appctx union
13455 - BUG/MINOR: lua/cli: bad error message
13456 - MEDIUM: lua: use memory pool for hlua struct in applets
13457 - MINOR: lua/signals: Remove Lua part from signals.
13458 - DOC: cli: show cli sockets
13459 - MINOR: cli: automatically enable a CLI I/O handler when there's no parser
13460 - CLEANUP: memory: remove the now unused cli_parse_show_pools() function
13461 - CLEANUP: applet: group all CLI contexts together
13462 - CLEANUP: stats: move a misplaced stats context initialization
13463 - MINOR: cli: add two general purpose pointers and integers in the CLI struct
13464 - MINOR: appctx/cli: remove the cli_socket entry from the appctx union
13465 - MINOR: appctx/cli: remove the env entry from the appctx union
13466 - MINOR: appctx/cli: remove the "be" entry from the appctx union
13467 - MINOR: appctx/cli: remove the "dns" entry from the appctx union
13468 - MINOR: appctx/cli: remove the "server_state" entry from the appctx union
13469 - MINOR: appctx/cli: remove the "tlskeys" entry from the appctx union
13470 - CONTRIB: tcploop: add limits.h to fix build issue with some compilers
13471 - MINOR/DOC: lua: just precise one thing
13472 - DOC: fix small typo in fe_id (backend instead of frontend)
13473 - BUG/MINOR: Fix the sending function in Lua's cosocket
13474 - BUG/MINOR: lua: memory leak executing tasks
13475 - BUG/MINOR: lua: bad return code
13476 - BUG/MINOR: lua: memleak when Lua/cli fails
13477 - MEDIUM: lua: remove Lua struct from session, and allocate it with memory pools
13478 - CLEANUP: haproxy: statify unexported functions
13479 - MINOR: haproxy: add a registration for build options
13480 - CLEANUP: wurfl: use the build options list to report it
13481 - CLEANUP: 51d: use the build options list to report it
13482 - CLEANUP: da: use the build options list to report it
13483 - CLEANUP: namespaces: use the build options list to report it
13484 - CLEANUP: tcp: use the build options list to report transparent modes
13485 - CLEANUP: lua: use the build options list to report it
13486 - CLEANUP: regex: use the build options list to report the regex type
13487 - CLEANUP: ssl: use the build options list to report the SSL details
13488 - CLEANUP: compression: use the build options list to report the algos
13489 - CLEANUP: auth: use the build options list to report its support
13490 - MINOR: haproxy: add a registration for post-check functions
13491 - CLEANUP: checks: make use of the post-init registration to start checks
13492 - CLEANUP: filters: use the function registration to initialize all proxies
13493 - CLEANUP: wurfl: make use of the late init registration
13494 - CLEANUP: 51d: make use of the late init registration
13495 - CLEANUP: da: make use of the late init registration code
13496 - MINOR: haproxy: add a registration for post-deinit functions
13497 - CLEANUP: wurfl: register the deinit function via the dedicated list
13498 - CLEANUP: 51d: register the deinitialization function
13499 - CLEANUP: da: register the deinitialization function
13500 - CLEANUP: wurfl: move global settings out of the global section
13501 - CLEANUP: 51d: move global settings out of the global section
13502 - CLEANUP: da: move global settings out of the global section
13503 - MINOR: cfgparse: add two new functions to check arguments count
13504 - MINOR: cfgparse: move parsing of "ca-base" and "crt-base" to ssl_sock
13505 - MEDIUM: cfgparse: move all tune.ssl.* keywords to ssl_sock
13506 - MEDIUM: cfgparse: move maxsslconn parsing to ssl_sock
13507 - MINOR: cfgparse: move parsing of ssl-default-{bind,server}-ciphers to ssl_sock
13508 - MEDIUM: cfgparse: move ssl-dh-param-file parsing to ssl_sock
13509 - MEDIUM: compression: move the zlib-specific stuff from global.h to compression.c
13510 - BUG/MEDIUM: ssl: properly reset the reused_sess during a forced handshake
13511 - BUG/MEDIUM: ssl: avoid double free when releasing bind_confs
13512 - BUG/MINOR: stats: fix be/sessions/current out in typed stats
13513 - MINOR: tcp-rules: check that the listener exists before updating its counters
13514 - MEDIUM: spoe: don't create a dummy listener for outgoing connections
13515 - MINOR: listener: move the transport layer pointer to the bind_conf
13516 - MEDIUM: move listener->frontend to bind_conf->frontend
13517 - MEDIUM: ssl: remote the proxy argument from most functions
13518 - MINOR: connection: add a new prepare_bind_conf() entry to xprt_ops
13519 - MEDIUM: ssl_sock: implement ssl_sock_prepare_bind_conf()
13520 - MINOR: connection: add a new destroy_bind_conf() entry to xprt_ops
13521 - MINOR: ssl_sock: implement ssl_sock_destroy_bind_conf()
13522 - MINOR: server: move the use_ssl field out of the ifdef USE_OPENSSL
13523 - MINOR: connection: add a minimal transport layer registration system
13524 - CLEANUP: connection: remove all direct references to raw_sock and ssl_sock
13525 - CLEANUP: connection: unexport raw_sock and ssl_sock
13526 - MINOR: connection: add new prepare_srv()/destroy_srv() entries to xprt_ops
13527 - MINOR: ssl_sock: implement and use prepare_srv()/destroy_srv()
13528 - CLEANUP: ssl: move tlskeys_finalize_config() to a post_check callback
13529 - CLEANUP: ssl: move most ssl-specific global settings to ssl_sock.c
13530 - BUG/MINOR: backend: nbsrv() should return 0 if backend is disabled
13531 - BUG/MEDIUM: ssl: for a handshake when server-side SNI changes
13532 - BUG/MINOR: systemd: potential zombie processes
13533 - DOC: Add timings events schemas
13534 - BUILD: lua: build failed on FreeBSD.
13535 - MINOR: samples: add xx-hash functions
13536 - MEDIUM: regex: pcre2 support
13537 - BUG/MINOR: option prefer-last-server must be ignored in some case
13538 - MINOR: stats: Support "select all" for backend actions
13539 - BUG/MINOR: sample-fetches/stick-tables: bad type for the sample fetches sc*_get_gpt0
13540 - BUG/MAJOR: channel: Fix the definition order of channel analyzers
13541 - BUG/MINOR: http: report real parser state in error captures
13542 - BUILD: scripts: automatically update the branch in version.h when releasing
13543 - MINOR: tools: add a generic hexdump function for debugging
13544 - BUG/MAJOR: http: fix risk of getting invalid reports of bad requests
13545 - MINOR: http: custom status reason.
13546 - MINOR: connection: add sample fetch "fc_rcvd_proxy"
13547 - BUG/MINOR: config: emit a warning if http-reuse is enabled with incompatible options
13548 - BUG/MINOR: tools: fix off-by-one in port size check
13549 - BUG/MEDIUM: server: consider AF_UNSPEC as a valid address family
13550 - MEDIUM: server: split the address and the port into two different fields
13551 - MINOR: tools: make str2sa_range() return the port in a separate argument
13552 - MINOR: server: take the destination port from the port field, not the addr
13553 - MEDIUM: server: disable protocol validations when the server doesn't resolve
13554 - BUG/MEDIUM: tools: do not force an unresolved address to AF_INET:0.0.0.0
13555 - BUG/MINOR: ssl: EVP_PKEY must be freed after X509_get_pubkey usage
13556 - BUG/MINOR: ssl: assert on SSL_set_shutdown with BoringSSL
13557 - MINOR: Use "500 Internal Server Error" for 500 error/status code message.
13558 - MINOR: proto_http.c 502 error txt typo.
13559 - DOC: add deprecation notice to "block"
13560 - MINOR: compression: fix -vv output without zlib/slz
13561 - BUG/MINOR: Reset errno variable before calling strtol(3)
13562 - MINOR: ssl: don't show prefer-server-ciphers output
13563 - OPTIM/MINOR: config: Optimize fullconn automatic computation loading configuration
13564 - BUG/MINOR: stream: Fix how backend-specific analyzers are set on a stream
13565 - MAJOR: ssl: bind configuration per certificat
13566 - MINOR: ssl: add curve suite for ECDHE negotiation
13567 - MINOR: checks: Add agent-addr config directive
13568 - MINOR: cli: Add possiblity to change agent config via CLI/socket
13569 - MINOR: doc: Add docs for agent-addr configuration variable
13570 - MINOR: doc: Add docs for agent-addr and agent-send CLI commands
13571 - BUILD: ssl: fix to build (again) with boringssl
13572 - BUILD: ssl: fix build on OpenSSL 1.0.0
13573 - BUILD: ssl: silence a warning reported for ERR_remove_state()
13574 - BUILD: ssl: eliminate warning with OpenSSL 1.1.0 regarding RAND_pseudo_bytes()
13575 - BUILD: ssl: kill a build warning introduced by BoringSSL compatibility
13576 - BUG/MEDIUM: tcp: don't poll for write when connect() succeeds
13577 - BUG/MINOR: unix: fix connect's polling in case no data are scheduled
13578 - MINOR: server: extend the flags to 32 bits
13579 - BUG/MINOR: lua: Map.end are not reliable because "end" is a reserved keyword
13580 - MINOR: dns: give ability to dns_init_resolvers() to close a socket when requested
13581 - BUG/MAJOR: dns: restart sockets after fork()
13582 - MINOR: chunks: implement a simple dynamic allocator for trash buffers
13583 - BUG/MEDIUM: http: prevent redirect from overwriting a buffer
13584 - BUG/MEDIUM: filters: Do not truncate HTTP response when body length is undefined
13585 - BUG/MEDIUM: http: Prevent replace-header from overwriting a buffer
13586 - BUG/MINOR: http: Return an error when a replace-header rule failed on the response
13587 - BUG/MINOR: sendmail: The return of vsnprintf is not cleanly tested
13588 - BUG/MAJOR: ssl: fix a regression in ssl_sock_shutw()
13589 - BUG/MAJOR: lua segmentation fault when the request is like 'GET ?arg=val HTTP/1.1'
13590 - BUG/MEDIUM: config: reject anything but "if" or "unless" after a use-backend rule
13591 - MINOR: http: don't close when redirect location doesn't start with "/"
13592 - MEDIUM: boringssl: support native multi-cert selection without bundling
13593 - BUG/MEDIUM: ssl: fix verify/ca-file per certificate
13594 - BUG/MEDIUM: ssl: switchctx should not return SSL_TLSEXT_ERR_ALERT_WARNING
13595 - MINOR: ssl: removes SSL_CTX_set_ssl_version call and cleanup CTX creation.
13596 - BUILD: ssl: fix build with -DOPENSSL_NO_DH
13597 - MEDIUM: ssl: add new sample-fetch which captures the cipherlist
13598 - MEDIUM: ssl: remove ssl-options from crt-list
13599 - BUG/MEDIUM: ssl: in bind line, ssl-options after 'crt' are ignored.
13600 - BUG/MINOR: ssl: fix cipherlist captures with sustainable SSL calls
13601 - MINOR: ssl: improved cipherlist captures
13602 - BUG/MINOR: spoe: Fix soft stop handler using a specific id for spoe filters
13603 - BUG/MINOR: spoe: Fix parsing of arguments in spoe-message section
13604 - MAJOR: spoe: Add support of pipelined and asynchronous exchanges with agents
13605 - MINOR: spoe: Add support for pipelining/async capabilities in the SPOA example
13606 - MINOR: spoe: Remove SPOE details from the appctx structure
13607 - MINOR: spoe: Add status code in error variable instead of hardcoded value
13608 - MINOR: spoe: Send a log message when an error occurred during event processing
13609 - MINOR: spoe: Check the scope of sample fetches used in SPOE messages
13610 - MEDIUM: spoe: Be sure to wakeup the good entity waiting for a buffer
13611 - MINOR: spoe: Use the min of all known max_frame_size to encode messages
13612 - MAJOR: spoe: Add support of payload fragmentation in NOTIFY frames
13613 - MINOR: spoe: Add support for fragmentation capability in the SPOA example
13614 - MAJOR: spoe: refactor the filter to clean up the code
13615 - MINOR: spoe: Handle NOTIFY frames cancellation using ABORT bit in ACK frames
13616 - REORG: spoe: Move struct and enum definitions in dedicated header file
13617 - REORG: spoe: Move low-level encoding/decoding functions in dedicated header file
13618 - MINOR: spoe: Improve implementation of the payload fragmentation
13619 - MINOR: spoe: Add support of negation for options in SPOE configuration file
13620 - MINOR: spoe: Add "pipelining" and "async" options in spoe-agent section
13621 - MINOR: spoe: Rely on alertif_too_many_arg during configuration parsing
13622 - MINOR: spoe: Add "send-frag-payload" option in spoe-agent section
13623 - MINOR: spoe: Add "max-frame-size" statement in spoe-agent section
13624 - DOC: spoe: Update SPOE documentation to reflect recent changes
13625 - MINOR: config: warn when some HTTP rules are used in a TCP proxy
13626 - BUG/MEDIUM: ssl: Clear OpenSSL error stack after trying to parse OCSP file
13627 - BUG/MEDIUM: cli: Prevent double free in CLI ACL lookup
13628 - BUG/MINOR: Fix "get map <map> <value>" CLI command
13629 - MINOR: Add nbsrv sample converter
13630 - CLEANUP: Replace repeated code to count usable servers with be_usable_srv()
13631 - MINOR: Add hostname sample fetch
13632 - CLEANUP: Remove comment that's no longer valid
13633 - MEDIUM: http_error_message: txn->status / http_get_status_idx.
13634 - MINOR: http-request tarpit deny_status.
13635 - CLEANUP: http: make http_server_error() not set the status anymore
13636 - MEDIUM: stats: Add JSON output option to show (info|stat)
13637 - MEDIUM: stats: Add show json schema
13638 - BUG/MAJOR: connection: update CO_FL_CONNECTED before calling the data layer
13639 - MINOR: server: Add dynamic session cookies.
13640 - MINOR: cli: Let configure the dynamic cookies from the cli.
13641 - BUG/MINOR: checks: attempt clean shutw for SSL check
13642 - CONTRIB: tcploop: make it build on FreeBSD
13643 - CONTRIB: tcploop: fix time format to silence build warnings
13644 - CONTRIB: tcploop: report action 'K' (kill) in usage message
13645 - CONTRIB: tcploop: fix connect's address length
13646 - CONTRIB: tcploop: use the trash instead of NULL for recv()
13647 - BUG/MEDIUM: listener: do not try to rebind another process' socket
13648 - BUG/MEDIUM server: Fix crash when dynamic is defined, but not key is provided.
13649 - CLEANUP: config: Typo in comment.
13650 - BUG/MEDIUM: filters: Fix channels synchronization in flt_end_analyze
13651 - TESTS: add a test configuration to stress handshake combinations
13652 - BUG/MAJOR: stream-int: do not depend on connection flags to detect connection
13653 - BUG/MEDIUM: connection: ensure to always report the end of handshakes
13654 - MEDIUM: connection: don't test for CO_FL_WAKE_DATA
13655 - CLEANUP: connection: completely remove CO_FL_WAKE_DATA
13656 - BUG: payload: fix payload not retrieving arbitrary lengths
13657 - BUILD: ssl: simplify SSL_CTX_set_ecdh_auto compatibility
13658 - BUILD: ssl: fix OPENSSL_NO_SSL_TRACE for boringssl and libressl
13659 - BUG/MAJOR: http: fix typo in http_apply_redirect_rule
13660 - MINOR: doc: 2.4. Examples should be 2.5. Examples
13661 - BUG/MEDIUM: stream: fix client-fin/server-fin handling
13662 - MINOR: fd: add a new flag HAP_POLL_F_RDHUP to struct poller
13663 - BUG/MINOR: raw_sock: always perfom the last recv if RDHUP is not available
13664 - OPTIM: poll: enable support for POLLRDHUP
13665 - MINOR: kqueue: exclusively rely on the kqueue returned status
13666 - MEDIUM: kqueue: take care of EV_EOF to improve polling status accuracy
13667 - MEDIUM: kqueue: only set FD_POLL_IN when there are pending data
13668 - DOC/MINOR: Fix typos in proxy protocol doc
13669 - DOC: Protocol doc: add checksum, TLV type ranges
13670 - DOC: Protocol doc: add SSL TLVs, rename CHECKSUM
13671 - DOC: Protocol doc: add noop TLV
13672 - MEDIUM: global: add a 'hard-stop-after' option to cap the soft-stop time
13673 - MINOR: dns: improve DNS response parsing to use as many available records as possible
13674 - BUG/MINOR: cfgparse: loop in tracked servers lists not detected by check_config_validity().
13675 - MINOR: server: irrelevant error message with 'default-server' config file keyword.
13676 - MINOR: server: Make 'default-server' support 'backup' keyword.
13677 - MINOR: server: Make 'default-server' support 'check-send-proxy' keyword.
13678 - CLEANUP: server: code alignement.
13679 - MINOR: server: Make 'default-server' support 'non-stick' keyword.
13680 - MINOR: server: Make 'default-server' support 'send-proxy' and 'send-proxy-v2 keywords.
13681 - MINOR: server: Make 'default-server' support 'check-ssl' keyword.
13682 - MINOR: server: Make 'default-server' support 'force-sslv3' and 'force-tlsv1[0-2]' keywords.
13683 - CLEANUP: server: code alignement.
13684 - MINOR: server: Make 'default-server' support 'no-ssl*' and 'no-tlsv*' keywords.
13685 - MINOR: server: Make 'default-server' support 'ssl' keyword.
13686 - MINOR: server: Make 'default-server' support 'send-proxy-v2-ssl*' keywords.
13687 - CLEANUP: server: code alignement.
13688 - MINOR: server: Make 'default-server' support 'verify' keyword.
13689 - MINOR: server: Make 'default-server' support 'verifyhost' setting.
13690 - MINOR: server: Make 'default-server' support 'check' keyword.
13691 - MINOR: server: Make 'default-server' support 'track' setting.
13692 - MINOR: server: Make 'default-server' support 'ca-file', 'crl-file' and 'crt' settings.
13693 - MINOR: server: Make 'default-server' support 'redir' keyword.
13694 - MINOR: server: Make 'default-server' support 'observe' keyword.
13695 - MINOR: server: Make 'default-server' support 'cookie' keyword.
13696 - MINOR: server: Make 'default-server' support 'ciphers' keyword.
13697 - MINOR: server: Make 'default-server' support 'tcp-ut' keyword.
13698 - MINOR: server: Make 'default-server' support 'namespace' keyword.
13699 - MINOR: server: Make 'default-server' support 'source' keyword.
13700 - MINOR: server: Make 'default-server' support 'sni' keyword.
13701 - MINOR: server: Make 'default-server' support 'addr' keyword.
13702 - MINOR: server: Make 'default-server' support 'disabled' keyword.
13703 - MINOR: server: Add 'no-agent-check' server keyword.
13704 - DOC: server: Add docs for "server" and "default-server" new "no-*" and other settings.
13705 - MINOR: doc: fix use-server example (imap vs mail)
13706 - BUG/MEDIUM: tcp: don't require privileges to bind to device
13707 - BUILD: make the release script use shortlog for the final changelog
13708 - BUILD: scripts: fix typo in announce-release error message
13709 - CLEANUP: time: curr_sec_ms doesn't need to be exported
13710 - BUG/MEDIUM: server: Wrong server default CRT filenames initialization.
13711 - BUG/MEDIUM: peers: fix buffer overflow control in intdecode.
13712 - BUG/MEDIUM: buffers: Fix how input/output data are injected into buffers
13713 - BUG/MINOR: http: Fix conditions to clean up a txn and to handle the next request
13714 - CLEANUP: http: Remove channel_congested function
13715 - CLEANUP: buffers: Remove buffer_bounce_realign function
13716 - CLEANUP: buffers: Remove buffer_contig_area and buffer_work_area functions
13717 - MINOR: http: remove useless check on HTTP_MSGF_XFER_LEN for the request
13718 - MINOR: http: Add debug messages when HTTP body analyzers are called
13719 - BUG/MEDIUM: http: Fix blocked HTTP/1.0 responses when compression is enabled
13720 - BUG/MINOR: filters: Don't force the stream's wakeup when we wait in flt_end_analyze
13721 - DOC: fix parenthesis and add missing "Example" tags
13722 - DOC: update the contributing file
13723 - DOC: log-format/tcplog/httplog update
13724 - MINOR: config parsing: add warning when log-format/tcplog/httplog is overriden in "defaults" sections
13725
Willy Tarreau0e658fb2016-11-25 16:55:50 +0100137262016/11/25 : 1.8-dev0
13727
Willy Tarreaue59fcdd2016-11-25 16:39:17 +0100137282016/11/25 : 1.7.0
13729 - SCRIPTS: make publish-release also copy the new SPOE doc
13730 - BUILD: http: include types/sample.h in proto_http.h
13731 - BUILD: debug/flags: remove test for SF_COMP_READY
13732 - CONTRIB: debug/flags: add check for SF_ERR_CHK_PORT
13733 - MINOR: lua: add function which return true if the channel is full.
13734 - MINOR: lua: add ip addresses and network manipulation function
13735 - CONTRIB: tcploop: scriptable TCP I/O for debugging purposes
13736 - CONTRIB: tcploop: implement fork()
13737 - CONTRIB: tcploop: implement logging when called with -v
13738 - CONTRIB: tcploop: update the usage output
13739 - CONTRIB: tcploop: support sending plain strings
13740 - CONTRIB: tcploop: don't report failed send() or recv()
13741 - CONTRIB: tcploop: add basic loops via a jump instruction
13742 - BUG/MEDIUM: channel: bad unlikely macro
13743 - CLEANUP: lua: move comment
13744 - CLEANUP: lua: control executed twice
13745 - BUG/MEDIUM: ssl: Store certificate filename in a variable
13746 - BUG/MINOR: ssl: Print correct filename when error occurs reading OCSP
13747 - CLEANUP: ssl: Remove goto after return dead code
13748 - CLEANUP: ssl: Fix bind keywords name in comments
13749 - DOC: ssl: Use correct wording for ca-sign-pass
13750 - CLEANUP: lua: avoid directly calling getsockname/getpeername()
13751 - BUG/MINOR: stick-table: handle out-of-memory condition gracefully
13752 - MINOR: cli: add private pointer and release function
13753 - MEDIUM: lua: Add cli handler for Lua
13754 - BUG/MEDIUM: connection: check the control layer before stopping polling
13755 - DEBUG: connection: mark the closed FDs with a value that is easier to detect
13756 - BUG/MEDIUM: stick-table: fix regression caused by recent fix for out-of-memory
13757 - BUG/MINOR: cli: properly decrement ref count on tables during failed dumps
13758 - BUG/MEDIUM: lua: In some case, the return of sample-fetche is ignored
13759 - MINOR: filters: Add check_timeouts callback to handle timers expiration on streams
13760 - MINOR: spoe: Add 'timeout processing' option to limit time to process an event
13761 - MINOR: spoe: Remove useless 'timeout ack' option
13762 - MINOR: spoe: Add 'option continue-on-error' statement in spoe-agent section
13763 - MINOR: spoe: Add "maxconnrate" and "maxerrrate" statements
13764 - MINOR: spoe: Add "option set-on-error" statement
13765 - MINOR: stats: correct documentation of process ID for typed output
13766 - BUILD: contrib: fix ip6range build on Centos 7
13767 - BUILD: fix build on Solaris 10/11
13768 - BUG/MINOR: cli: fix pointer size when reporting data/transport layer name
13769 - BUG/MINOR: cli: dequeue from the proxy when changing a maxconn
13770 - BUG/MINOR: cli: wake up the CLI's task after a timeout update
13771 - MINOR: connection: add a few functions to report the data and xprt layers' names
13772 - MINOR: connection: add names for transport and data layers
13773 - REORG: cli: split dumpstats.c in src/cli.c and src/stats.c
13774 - REORG: cli: split dumpstats.h in stats.h and cli.h
13775 - REORG: cli: move ssl CLI functions to ssl_sock.c
13776 - REORG: cli: move map and acl code to map.c
13777 - REORG: cli: move show stat resolvers to dns.c
13778 - MINOR: cli: create new function cli_has_level() to validate permissions
13779 - MINOR: server: create new function cli_find_server() to find a server
13780 - MINOR: proxy: create new function cli_find_frontend() to find a frontend
13781 - REORG: cli: move 'set server' to server.c
13782 - REORG: cli: move 'show pools' to memory.c
13783 - REORG: cli: move 'show servers' to proxy.c
13784 - REORG: cli: move 'show sess' to stream.c
13785 - REORG: cli: move 'show backend' to proxy.c
13786 - REORG: cli: move get/set weight to server.c
13787 - REORG: cli: move "show stat" to stats.c
13788 - REORG: cli: move "show info" to stats.c
13789 - REORG: cli: move dump_text(), dump_text_line(), and dump_binary() to standard.c
13790 - REORG: cli: move table dump/clear/set to stick_table.c
13791 - REORG: cli: move "show errors" out of cli.c
13792 - REORG: cli: make "show env" also use the generic keyword registration
13793 - REORG: cli: move "set timeout" to its own handler
13794 - REORG: cli: move "clear counters" to stats.c
13795 - REORG: cli: move "set maxconn global" to its own handler
13796 - REORG: cli: move "set maxconn server" to server.c
13797 - REORG: cli: move "set maxconn frontend" to proxy.c
13798 - REORG: cli: move "shutdown sessions server" to stream.c
13799 - REORG: cli: move "shutdown session" to stream.c
13800 - REORG: cli: move "shutdown frontend" to proxy.c
13801 - REORG: cli: move "{enable|disable} frontend" to proxy.c
13802 - REORG: cli: move "{enable|disable} server" to server.c
13803 - REORG: cli: move "{enable|disable} health" to server.c
13804 - REORG: cli: move "{enable|disable} agent" to server.c
13805 - REORG: cli: move the "set rate-limit" functions to their own parser
13806 - CLEANUP: cli: rename STAT_CLI_* to CLI_ST_*
13807 - CLEANUP: cli: simplify the request parser a little bit
13808 - CLEANUP: cli: remove assignments to st0 and st2 in keyword parsers
13809 - BUILD: server: remove a build warning introduced by latest series
13810 - BUG/MINOR: log-format: uncatched memory allocation functions
13811 - CLEANUP: log-format: useless file and line in json converter
13812 - CLEANUP/MINOR: log-format: unexport functions parse_logformat_var_args() and parse_logformat_var()
13813 - CLEANUP: log-format: fix return code of the function parse_logformat_var()
13814 - CLEANUP: log-format: fix return code of function parse_logformat_var_args()
13815 - CLEANUP: log-format: remove unused arguments
13816 - MEDIUM: log-format: strict parsing and enable fail
13817 - MEDIUM: log-format/conf: take into account the parse_logformat_string() return code
13818 - BUILD: ssl: make the SSL layer build again with openssl 0.9.8
13819 - BUILD: vars: remove a build warning on vars.c
13820 - MINOR: lua: add utility function for check boolean argument
13821 - MINOR: lua: Add tokenize function.
13822 - BUG/MINOR: conf: calloc untested
13823 - MINOR: http/conf: store the use_backend configuration file and line for logs
13824 - MEDIUM: log-format: Use standard HAProxy log system to report errors
13825 - CLEANUP: sample: report "converter" instead of "conv method" in error messages
13826 - BUG: spoe: Fix parsing of SPOE actions in ACK frames
13827 - MINOR: cli: make "show stat" support a proxy name
13828 - MINOR: cli: make "show errors" support a proxy name
13829 - MINOR: cli: make "show errors" capable of dumping only request or response
13830 - BUG/MINOR: freq-ctr: make swrate_add() support larger values
13831 - CLEANUP: counters: move from 3 types to 2 types
13832 - CLEANUP: cfgparse: cascade the warnif_misplaced_* rules
13833 - REORG: tcp-rules: move tcp rules processing to their own file
13834 - REORG: stkctr: move all the stick counters processing to stick-tables.c
13835 - DOC: update the roadmap file with the latest changes
13836
Willy Tarreaud5d890b2016-11-09 23:18:17 +0100138372016/11/09 : 1.7-dev6
13838 - DOC: fix the entry for hash-balance-factor config option
13839 - DOC: Fix typo in description of `-st` parameter in man page
13840 - CLEANUP: cfgparse: Very minor spelling correction
13841 - MINOR: examples: Update haproxy.spec URLs to haproxy.org
13842 - BUG/MEDIUM: peers: on shutdown, wake up the appctx, not the stream
13843 - BUG/MEDIUM: peers: fix use after free in peer_session_create()
13844 - MINOR: peers: make peer_session_forceshutdown() use the appctx and not the stream
13845 - MINOR: peers: remove the pointer to the stream
13846 - BUG/MEDIUM: systemd-wrapper: return correct exit codes
13847 - DOC: stats: provide state details for show servers state
13848 - MEDIUM: tools: make str2ip2() preserve existing ports
13849 - CLEANUP: tools: make ipcpy() preserve the original port
13850 - OPTIM: http: move all http character classs tables into a single one
13851 - OPTIM: http: improve parsing performance of long header lines
13852 - OPTIM: http: improve parsing performance of long URIs
13853 - OPTIM: http: optimize lookup of comma and quote in header values
13854 - BUG/MEDIUM: srv-state: properly restore the DRAIN state
13855 - BUG/MINOR: srv-state: allow to have both CMAINT and FDRAIN flags
13856 - MINOR: server: do not emit warnings/logs/alerts on server state changes at boot
13857 - BUG/MEDIUM: servers: properly propagate the maintenance states during startup
13858 - MEDIUM: wurfl: add Scientiamobile WURFL device detection module
13859 - DOC: move the device detection modules documentation to their own files
13860 - CLEANUP: wurfl: reduce exposure in the rest of the code
13861 - MEDIUM: ssl: Add support for OpenSSL 1.1.0
13862 - MINOR: stream: make option contstats usable again
13863 - MEDIUM: tools: make str2sa_range() return the FQDN even when not resolving
13864 - MINOR: init: move apply_server_state in haproxy.c before MODE_CHECK
13865 - MAJOR: server: postpone address resolution
13866 - MINOR: new srv_admin flag: SRV_ADMF_RMAINT
13867 - MINOR: server: indicate in the logs when RMAINT is cleared
13868 - MINOR: stats: indicate it when a server is down due to resolution
13869 - MINOR: server: make srv_set_admin_state() capable of telling why this happens
13870 - MINOR: dns: implement extra 'hold' timers.
13871 - MAJOR: dns: runtime resolution can change server admin state
13872 - MEDIUM: cli: leave the RMAINT state when setting an IP address on the CLI
13873 - MEDIUM: server: add a new init-addr server line setting
13874 - MEDIUM: server: make use of init-addr
13875 - MINOR: server: implement init-addr none
13876 - MEDIUM: server: make libc resolution failure non-fatal
13877 - MINOR: server: add support for explicit numeric address in init-addr
13878 - DOC: add some documentation for the "init-addr" server keyword
13879 - MINOR: init: add -dr to ignore server address resolution failures
13880 - MEDIUM: server: do not restrict anymore usage of IP address from the state file
13881 - BUG: vars: Fix 'set-var' converter because of a typo
13882 - CLEANUP: remove last references to 'ruleset' section
13883 - MEDIUM: filters: Add attch/detach and stream_set_backend callbacks
13884 - MINOR: filters: Update filters documentation accordingly to recent changes
13885 - MINOR: filters: Call stream_set_backend callbacks before updating backend stats
13886 - MINOR: filters: Remove backend filters attached to a stream only for HTTP streams
13887 - MINOR: flt_trace: Add hexdump option to dump forwarded data
13888 - MINOR: cfgparse: Add functions to backup and restore registered sections
13889 - MINOR: cfgparse: Parse scope lines and save the last one parsed
13890 - REORG: sample: move code to release a sample expression in sample.c
13891 - MINOR: vars: Allow '.' in variable names
13892 - MINOR: vars: Add vars_set_by_name_ifexist function
13893 - MEDIUM: vars: Add a per-process scope for variables
13894 - MINOR: vars: Add 'unset-var' action/converter
13895 - MAJOR: spoe: Add an experimental Stream Processing Offload Engine
13896 - MINOR: spoe: add random ip-reputation service as SPOA example
13897 - MINOR: spoe/checks: Add support for SPOP health checks
13898 - DOC: update ROADMAP file
13899
Willy Tarreau608efa12016-10-25 22:22:00 +0200139002016/10/25 : 1.7-dev5
13901 - MINOR: cfgparse: few memory leaks fixes.
13902 - MEDIUM: log: Decompose %Tq in %Th %Ti %TR
13903 - CLEANUP: logs: remove unused log format field definitions
13904 - BUILD/MAJOR:updated 51d Trie implementation to incorperate latest update to 51Degrees.c
13905 - BUG/MAJOR: stream: properly mark the server address as unset on connect retry
13906 - CLEANUP: proto_http: Removing useless variable assignation
13907 - CLEANUP: dumpstats: Removing useless variables allocation
13908 - CLEANUP: dns: Removing usless variable & assignation
13909 - BUG/MINOR: payload: fix SSLv2 version parser
13910 - MINOR: cli: allow the semi-colon to be escaped on the CLI
13911 - MINOR: cli: change a server health check port through the stats socket
13912 - BUG/MINOR: Fix OSX compilation errors
13913 - MAJOR: check: find out which port to use for health check at run time
13914 - MINOR: server: introduction of 3 new server flags
13915 - MINOR: new update_server_addr_port() function to change both server's ADDR and service PORT
13916 - MINOR: cli: ability to change a server's port
13917 - CLEANUP/MINOR dns: comment do not follow up code update
13918 - MINOR: chunk: new strncat function
13919 - MINOR: dns: wrong DNS_MAX_UDP_MESSAGE value
13920 - MINOR: dns: new MAX values
13921 - MINOR: dns: new macro to compute DNS header size
13922 - MINOR: dns: new DNS structures to store received packets
13923 - MEDIUM: dns: new DNS response parser
13924 - MINOR: dns: query type change when last record is a CNAME
13925 - MINOR: dns: proper domain name validation when receiving DNS response
13926 - MINOR: dns: comments in types/dns.h about structures endianness
13927 - BUG/MINOR: displayed PCRE version is running release
13928 - MINOR: show Built with PCRE version
13929 - MINOR: show Running on zlib version
13930 - MEDIUM: make SO_REUSEPORT configurable
13931 - MINOR: enable IP_BIND_ADDRESS_NO_PORT on backend connections
13932 - BUG/MEDIUM: http/compression: Fix how chunked data are copied during the HTTP body parsing
13933 - BUG/MINOR: stats: report the correct conn_time in backend's html output
13934 - BUG/MEDIUM: dns: don't randomly crash on out-of-memory
13935 - MINOR: Add fe_req_rate sample fetch
13936 - MEDIUM: peers: Fix a peer stick-tables synchronization issue.
13937 - MEDIUM: cli: register CLI keywords with cli_register_kw()
13938 - BUILD: Make use of accept4() on OpenBSD.
13939 - MINOR: tcp: make set-src/set-src-port and set-dst/set-dst-port commutative
13940 - DOC: fix missed entry for "set-{src,dst}{,-port}"
13941 - BUG/MINOR: vars: use sess and not s->sess in action_store()
13942 - BUG/MINOR: vars: make smp_fetch_var() more robust against misuses
13943 - BUG/MINOR: vars: smp_fetch_var() doesn't depend on HTTP but on the session
13944 - MINOR: stats: output dcon
13945 - CLEANUP: tcp rules: mention everywhere that tcp-conn rules are L4
13946 - MINOR: counters: add new fields for denied_sess
13947 - MEDIUM: tcp: add registration and processing of TCP L5 rules
13948 - MINOR: stats: emit dses
13949 - DOC: document tcp-request session
13950 - MINOR: ssl: add debug traces
13951 - BUILD/CLEANUP: ssl: Check BIO_reset() return code
13952 - BUG/MINOR: ssl: Check malloc return code
13953 - BUG/MINOR: ssl: prevent multiple entries for the same certificate
13954 - BUG/MINOR: systemd: make the wrapper return a non-null status code on error
13955 - BUG/MINOR: systemd: always restore signals before execve()
13956 - BUG/MINOR: systemd: check return value of calloc()
13957 - MINOR: systemd: report it when execve() fails
13958 - BUG/MEDIUM: systemd: let the wrapper know that haproxy has completed or failed
13959 - MINOR: proxy: add 'served' field to proxy, equal to total of all servers'
13960 - MINOR: backend: add hash-balance-factor option for hash-type consistent
13961 - MINOR: server: compute a "cumulative weight" to allow chash balancing to hit its target
13962 - MEDIUM: server: Implement bounded-load hash algorithm
13963 - SCRIPTS: make git-show-backports also dump a "git show" command
13964 - MINOR: build: Allow linking to device-atlas library file
13965 - MINOR: stats: Escape equals sign on socket dump
13966
Willy Tarreau41d5e3a2016-08-14 12:25:21 +0200139672016/08/14 : 1.7-dev4
13968 - MINOR: add list_append_word function
13969 - MEDIUM: init: use list_append_word in haproxy.c
13970 - MEDIUM: init: allow directory as argument of -f
13971 - CLEANUP: config: detect double registration of a config section
13972 - MINOR: log: add the %Td log-format specifier
13973 - MEDIUM: filters: Move HTTP headers filtering in its own callback
13974 - MINOR: filters: Simplify calls to analyzers using 2 new macros
13975 - MEDIUM: filters: Add pre and post analyzer callbacks
13976 - DOC: filters: Update the filters documentation accordingly to recent changes
13977 - BUG/MEDIUM: init: don't use environment locale
13978 - SCRIPTS: teach git-show-backports how to report upstream commits
13979 - SCRIPTS: make git-show-backports capable of limiting its history
13980 - BUG/MAJOR: fix listening IP address storage for frontends
13981 - BUG/MINOR: fix listening IP address storage for frontends (cont)
13982 - DOC: Fix typo so fetch is properly parsed by Cyril's converter
13983 - BUG/MAJOR: http: fix breakage of "reqdeny" causing random crashes
13984 - BUG/MEDIUM: stick-tables: fix breakage in table converters
13985 - MINOR: stick-table: change all stick-table converters' inputs to SMP_T_ANY
13986 - BUG/MEDIUM: dns: unbreak DNS resolver after header fix
13987 - BUILD: fix build on Solaris 11
13988 - BUG/MEDIUM: config: fix multiple declaration of section parsers
13989 - BUG/MEDIUM: stats: show servers state may show an servers from another backend
13990 - BUG/MEDIUM: fix risk of segfault with "show tls-keys"
13991 - MEDIUM: dumpstats: 'show tls-keys' is now able to show secrets
13992 - DOC: update doc about tls-tickets-keys dump
13993 - MEDIUM: tcp: add 'set-src' to 'tcp-request connection'
13994 - MINOR: set the CO_FL_ADDR_FROM_SET flags with 'set-src'
13995 - MEDIUM: tcp/http: add 'set-src-port' action
13996 - MEDIUM: tcp/http: new set-dst/set-dst-port actions
13997 - BUG/MEDIUM: sticktables: segfault in some configuration error cases
13998 - BUILD/MEDIUM: rebuild everything when an include file is changed
13999 - BUILD/MEDIUM: force a full rebuild if some build options change
14000 - BUG/MEDIUM: lua: converters doesn't work
14001 - BUG/MINOR: http: add-header: header name copied twice
14002 - BUG/MEDIUM: http: add-header: buffer overwritten
14003 - BUG/MINOR: ssl: fix potential memory leak in ssl_sock_load_dh_params()
14004 - MINOR: stream: export the function 'smp_create_src_stkctr'
14005 - BUG/MEDIUM: dumpstats: undefined behavior in stats_tlskeys_list()
14006 - MEDIUM: dumpstats: make stats_tlskeys_list() yield-aware during tls-keys dump
14007 - BUG/MINOR: http: url32+src should use the big endian version of url32
14008 - BUG/MINOR: http: url32+src should check cli_conn before using it
14009 - DOC: http: add documentation for url32 and url32+src
14010 - BUG/MINOR: fix http-response set-log-level parsing error
14011 - MINOR: systemd: Use variable for config and pidfile paths
14012 - MINOR: systemd: Perform sanity check on config before reload
14013 - MEDIUM: ssl: support SNI filters with multicerts
14014 - MINOR: ssl: crt-list parsing factor
14015 - BUILD: ssl: fix typo causing a build failure in the multicert patch
14016 - MINOR: listener: add the "accept-netscaler-cip" option to the "bind" keyword
14017 - MINOR: tcp: add "tcp-request connection expect-netscaler-cip layer4"
14018 - BUG/MINOR: init: always ensure that global.rlimit_nofile matches actual limits
14019 - BUG/MINOR: init: ensure that FD limit is raised to the max allowed
14020 - BUG/MEDIUM: external-checks: close all FDs right after the fork()
14021 - BUG/MAJOR: external-checks: use asynchronous signal delivery
14022 - BUG/MINOR: external-checks: do not unblock undesired signals
14023 - CLEANUP: external-check: don't block/unblock SIGCHLD when manipulating the list
14024 - BUG/MEDIUM: filters: Fix data filtering when data are modified
14025 - BUG/MINOR: filters: Fix HTTP parsing when a filter loops on data forwarding
14026 - BUG/MINOR: srv-state: fix incorrect output of state file
14027 - BUG/MINOR: ssl: close ssl key file on error
14028 - BUG/MINOR: http: fix misleading error message for response captures
14029 - BUG/BUILD: don't automatically run "make" on "make install"
14030 - DOC: add missing doc for http-request deny [deny_status <status>]
14031 - CLEANUP: dumpstats: u64 field is an unsigned type.
14032 - BUG/MEDIUM: http: unbreak uri/header/url_param hashing
14033 - BUG/MINOR: Rework slightly commit 9962f8fc to clean code and avoid mistakes
14034 - MINOR: new function my_realloc2 = realloc + free upon failure
14035 - CLEANUP: fixed some usages of realloc leading to memory leak
14036 - Revert "BUG/MINOR: ssl: fix potential memory leak in ssl_sock_load_dh_params()"
14037 - CLEANUP: connection: using internal struct to hold source and dest port.
14038 - DOC: spelling fixes
14039 - BUG/MINOR: ssl: fix potential memory leak in ssl_sock_load_dh_params()
14040 - BUG/MEDIUM: dns: fix alignment issues in the DNS response parser
14041 - BUG/MINOR: Fix endiness issue in DNS header creation code
14042 - BUG/MEDIUM: lua: the function txn_done() from sample fetches can crash
14043 - BUG/MEDIUM: lua: the function txn_done() from action wrapper can crash
14044 - MEDIUM: http: implement http-response track-sc* directive
14045 - BUG/MINOR: peers: Fix peers data decoding issue
14046 - BUG/MINOR: peers: don't count track-sc multiple times on errors
14047 - MINOR: standard: add function "escape_string"
14048 - BUG/MEDIUM: log: use function "escape_string" instead of "escape_chunk"
14049 - MINOR: tcp: Return TCP statistics like RTT and RTT variance
14050 - DOC: lua: remove old functions
14051 - BUG/MEDIUM: lua: somme HTTP manipulation functions are called without valid requests
14052 - DOC: fix json converter example and error message
14053 - BUG/MEDIUM: stream-int: completely detach connection on connect error
14054 - DOC: minor typo fixes to improve HTML parsing by haproxy-dconv
14055 - BUILD: make proto_tcp.c compatible with musl library
14056 - BUG/MAJOR: compression: initialize avail_in/next_in even during flush
14057 - BUG/MEDIUM: samples: make smp_dup() always duplicate the sample
14058 - MINOR: sample: implement smp_is_safe() and smp_make_safe()
14059 - MINOR: sample: provide smp_is_rw() and smp_make_rw()
14060 - BUG/MAJOR: server: the "sni" directive could randomly cause trouble
14061 - BUG/MEDIUM: stick-tables: do not fail on string keys with no allocated size
14062 - BUG/MEDIUM: stick-table: properly convert binary samples to keys
14063 - MINOR: sample: use smp_make_rw() in upper/lower converters
14064 - MINOR: tcp: add dst_is_local and src_is_local
14065 - BUG/MINOR: peers: some updates are pushed twice after a resync.
14066 - BUILD: protocol: fix some build errors on OpenBSD
14067 - BUILD: log: iovec requires to include sys/uio.h on OpenBSD
14068 - BUILD: tcp: do not include netinet/ip.h for IP_TTL
14069 - BUILD: connection: fix build breakage on openbsd due to missing in_systm.h
14070 - BUILD: checks: remove the last strcat and eliminate a warning on OpenBSD
14071 - BUILD: tcp: define SOL_TCP when only IPPROTO_TCP exists
14072 - BUILD: compression: remove a warning when no compression lib is used
14073 - BUILD: poll: remove unused hap_fd_isset() which causes a warning with clang
14074 - MINOR: tcp: add further tcp info fetchers
14075 - BUG/MINOR: peers: empty chunks after a resync.
14076 - BUG/MAJOR: stick-counters: possible crash when using sc_trackers with wrong table
14077 - MINOR: standard.c: ipcmp() function to compare 2 IP addresses stored in 2 struct sockaddr_storage
14078 - MINOR: standard.c: ipcpy() function to copy an IP address from a struct sockaddr_storage into an other one
14079 - MAJOR: listen section: don't use first bind port anymore when no server ports are provided
14080
Willy Tarreau7d1b48f2016-05-10 15:36:58 +0200140812016/05/10 : 1.7-dev3
14082 - MINOR: sample: Moves ARGS underlying type from 32 to 64 bits.
14083 - BUG/MINOR: log: Don't use strftime() which can clobber timezone if chrooted
14084 - BUILD: namespaces: fix a potential build warning in namespaces.c
14085 - MINOR: da: Using ARG12 macro for the sample fetch and the convertor.
14086 - DOC: add encoding to json converter example
14087 - BUG/MINOR: conf: "listener id" expects integer, but its not checked
14088 - DOC: Clarify tunes.vars.xxx-max-size settings
14089 - CLEANUP: chunk: adding NULL check to chunk_dup allocation.
14090 - CLEANUP: connection: fix double negation on memcmp()
14091 - BUG/MEDIUM: peers: fix incorrect age in frequency counters
14092 - BUG/MEDIUM: Fix RFC5077 resumption when more than TLS_TICKETS_NO are present
14093 - BUG/MAJOR: Fix crash in http_get_fhdr with exactly MAX_HDR_HISTORY headers
14094 - BUG/MINOR: lua: can't load external libraries
14095 - BUG/MINOR: prevent the dump of uninitialized vars
14096 - CLEANUP: map: it seems that the map were planed to be chained
14097 - MINOR: lua: move class registration facilities
14098 - MINOR: lua: remove some useless checks
14099 - CLEANUP: lua: Remove two same functions
14100 - MINOR: lua: refactor the Lua object registration
14101 - MINOR: lua: precise message when a critical error is catched
14102 - MINOR: lua: post initialization
14103 - MINOR: lua: Add internal function which strip spaces
14104 - MINOR: lua: convert field to lua type
14105 - DOC: "addr" parameter applies to both health and agent checks
14106 - DOC: timeout client: pointers to timeout http-request
14107 - DOC: typo on stick-store response
14108 - DOC: stick-table: amend paragraph blaming the loss of table upon reload
14109 - DOC: typo: ACL subdir match
14110 - DOC: typo: maxconn paragraph is wrong due to a wrong buffer size
14111 - DOC: regsub: parser limitation about the inability to use closing square brackets
14112 - DOC: typo: req.uri is now replaced by capture.req.uri
14113 - DOC: name set-gpt0 mismatch with the expected keyword
14114 - MINOR: http: sample fetch which returns unique-id
14115 - MINOR: dumpstats: extract stats fields enum and names
14116 - MINOR: dumpstats: split stats_dump_info_to_buffer() in two parts
14117 - MINOR: dumpstats: split stats_dump_fe_stats() in two parts
14118 - MINOR: dumpstats: split stats_dump_li_stats() in two parts
14119 - MINOR: dumpstats: split stats_dump_sv_stats() in two parts
14120 - MINOR: dumpstats: split stats_dump_be_stats() in two parts
14121 - MINOR: lua: dump general info
14122 - MINOR: lua: add class proxy
14123 - MINOR: lua: add class server
14124 - MINOR: lua: add class listener
14125 - BUG/MEDIUM: stick-tables: some sample-fetch doesn't work in the connection state.
14126 - MEDIUM: proxy: use dynamic allocation for error dumps
14127 - CLEANUP: remove unneeded casts
14128 - CLEANUP: uniformize last argument of malloc/calloc
14129 - DOC: fix "needed" typo
14130 - BUG/MINOR: dumpstats: fix write to global chunk
14131 - BUG/MINOR: dns: inapropriate way out after a resolution timeout
14132 - BUG/MINOR: dns: trigger a DNS query type change on resolution timeout
14133 - CLEANUP: proto_http: few corrections for gcc warnings.
14134 - BUG/MINOR: DNS: resolution structure change
14135 - BUG/MINOR : allow to log cookie for tarpit and denied request
14136 - BUG/MEDIUM: ssl: rewind the BIO when reading certificates
14137 - OPTIM/MINOR: session: abort if possible before connecting to the backend
14138 - DOC: http: rename the unique-id sample and add the documentation
14139 - BUG/MEDIUM: trace.c: rdtsc() is defined in two files
14140 - BUG/MEDIUM: channel: fix miscalculation of available buffer space (2nd try)
14141 - BUG/MINOR: server: risk of over reading the pref_net array.
14142 - BUG/MINOR: cfgparse: couple of small memory leaks.
14143 - BUG/MEDIUM: sample: initialize the pointer before parse_binary call.
14144 - DOC: fix discrepancy in the example for http-request redirect
14145 - MINOR: acl: Add predefined METH_DELETE, METH_PUT
14146 - CLEANUP: .gitignore cleanup
14147 - DOC: Clarify IPv4 address / mask notation rules
14148 - CLEANUP: fix inconsistency between fd->iocb, proto->accept and accept()
14149 - BUG/MEDIUM: fix maxaccept computation on per-process listeners
14150 - BUG/MINOR: listener: stop unbound listeners on startup
14151 - BUG/MINOR: fix maxaccept computation according to the frontend process range
14152 - TESTS: add blocksig.c to run tests with all signals blocked
14153 - MEDIUM: unblock signals on startup.
14154 - MINOR: filters: Print the list of existing filters during HA startup
14155 - MINOR: filters: Typo in an error message
14156 - MINOR: filters: Filters must define the callbacks struct during config parsing
14157 - DOC: filters: Add filters documentation
14158 - BUG/MEDIUM: channel: don't allow to overwrite the reserve until connected
14159 - BUG/MEDIUM: channel: incorrect polling condition may delay event delivery
14160 - BUG/MEDIUM: channel: fix miscalculation of available buffer space (3rd try)
14161 - BUG/MEDIUM: log: fix risk of segfault when logging HTTP fields in TCP mode
14162 - MINOR: Add ability for agent-check to set server maxconn
14163 - CLEANUP: Use server_parse_maxconn_change_request for maxconn CLI updates
14164 - MINOR: filters: add opaque data
14165 - BUG/MEDIUM: lua: protects the upper boundary of the argument list for converters/fetches.
14166 - MINOR: lua: migrate the argument mask to 64 bits type.
14167 - BUG/MINOR: dumpstats: Fix the "Total bytes saved" counter in backends stats
14168 - BUG/MINOR: log: fix a typo that would cause %HP to log <BADREQ>
14169 - BUG/MEDIUM: http: fix incorrect reporting of server errors
14170 - MINOR: channel: add new function channel_congested()
14171 - BUG/MEDIUM: http: fix risk of CPU spikes with pipelined requests from dead client
14172 - BUG/MAJOR: channel: fix miscalculation of available buffer space (4th try)
14173 - BUG/MEDIUM: stream: ensure the SI_FL_DONT_WAKE flag is properly cleared
14174 - BUG/MEDIUM: channel: fix inconsistent handling of 4GB-1 transfers
14175 - BUG/MEDIUM: stats: show servers state may show an empty or incomplete result
14176 - BUG/MEDIUM: stats: show backend may show an empty or incomplete result
14177 - MINOR: stats: fix typo in help messages
14178 - MINOR: stats: show stat resolvers missing in the help message
14179 - BUG/MINOR: dns: fix DNS header definition
14180 - BUG/MEDIUM: dns: fix alignment issue when building DNS queries
14181 - CLEANUP: don't ignore scripts in .gitignore
14182 - BUILD: add a few release and backport scripts in scripts/
14183
Willy Tarreau8234f6d2016-03-14 00:10:05 +0100141842016/03/14 : 1.7-dev2
14185 - DOC: lua: fix lua API
14186 - DOC: mailers: typo in 'hostname' description
14187 - DOC: compression: missing mention of libslz for compression algorithm
14188 - BUILD/MINOR: regex: missing header
14189 - BUG/MINOR: stream: bad return code
14190 - DOC: lua: fix somme errors and add implicit types
14191 - MINOR: lua: add set/get priv for applets
14192 - BUG/MINOR: http: fix several off-by-one errors in the url_param parser
14193 - BUG/MINOR: http: Be sure to process all the data received from a server
14194 - MINOR: filters/http: Use a wrapper function instead of stream_int_retnclose
14195 - BUG/MINOR: chunk: make chunk_dup() always check and set dst->size
14196 - DOC: ssl: fixed some formatting errors in crt tag
14197 - MINOR: chunks: ensure that chunk_strcpy() adds a trailing zero
14198 - MINOR: chunks: add chunk_strcat() and chunk_newstr()
14199 - MINOR: chunk: make chunk_initstr() take a const string
14200 - MEDIUM: tools: add csv_enc_append() to preserve the original chunk
14201 - MINOR: tools: make csv_enc_append() always start at the first byte of the chunk
14202 - MINOR: lru: new function to delete <nb> least recently used keys
14203 - DOC: add Ben Shillito as the maintainer of 51d
14204 - BUG/MINOR: 51d: Ensures a unique domain for each configuration
14205 - BUG/MINOR: 51d: Aligns Pattern cache implementation with HAProxy best practices.
14206 - BUG/MINOR: 51d: Releases workset back to pool.
14207 - BUG/MINOR: 51d: Aligned const pointers to changes in 51Degrees.
14208 - CLEANUP: 51d: Aligned if statements with HAProxy best practices and removed casts from malloc.
14209 - MINOR: rename master process name in -Ds (systemd mode)
14210 - DOC: fix a few spelling mistakes
14211 - DOC: fix "workaround" spelling
14212 - BUG/MINOR: examples: Fixing haproxy.spec to remove references to .cfg files
14213 - MINOR: fix the return type for dns_response_get_query_id() function
14214 - MINOR: server state: missing LF (\n) on error message printed when parsing server state file
14215 - BUG/MEDIUM: dns: no DNS resolution happens if no ports provided to the nameserver
14216 - BUG/MAJOR: servers state: server port is erased when dns resolution is enabled on a server
14217 - BUG/MEDIUM: servers state: server port is used uninitialized
14218 - BUG/MEDIUM: config: Adding validation to stick-table expire value.
14219 - BUG/MEDIUM: sample: http_date() doesn't provide the right day of the week
14220 - BUG/MEDIUM: channel: fix miscalculation of available buffer space.
14221 - MEDIUM: pools: add a new flag to avoid rounding pool size up
14222 - BUG/MEDIUM: buffers: do not round up buffer size during allocation
14223 - BUG/MINOR: stream: don't force retries if the server is DOWN
14224 - BUG/MINOR: counters: make the sc-inc-gpc0 and sc-set-gpt0 touch the table
14225 - MINOR: unix: don't mention free ports on EAGAIN
14226 - BUG/CLEANUP: CLI: report the proper field states in "show sess"
14227 - MINOR: stats: send content-length with the redirect to allow keep-alive
14228 - BUG: stream_interface: Reuse connection even if the output channel is empty
14229 - DOC: remove old tunnel mode assumptions
14230 - BUG/MAJOR: http-reuse: fix risk of orphaned connections
14231 - BUG/MEDIUM: http-reuse: do not share private connections across backends
14232 - BUG/MINOR: ssl: Be sure to use unique serial for regenerated certificates
14233 - BUG/MINOR: stats: fix missing comma in stats on agent drain
14234 - MAJOR: filters: Add filters support
14235 - MINOR: filters: Do not reset stream analyzers if the client is gone
14236 - REORG: filters: Prepare creation of the HTTP compression filter
14237 - MAJOR: filters/http: Rewrite the HTTP compression as a filter
14238 - MEDIUM: filters: Use macros to call filters callbacks to speed-up processing
14239 - MEDIUM: filters: remove http_start_chunk, http_last_chunk and http_chunk_end
14240 - MEDIUM: filters: Replace filter_http_headers callback by an analyzer
14241 - MEDIUM: filters/http: Move body parsing of HTTP messages in dedicated functions
14242 - MINOR: filters: Add stream_filters structure to hide filters info
14243 - MAJOR: filters: Require explicit registration to filter HTTP body and TCP data
14244 - MINOR: filters: Remove unused or useless stuff and do small optimizations
14245 - MEDIUM: filters: Optimize the HTTP compression for chunk encoded response
14246 - MINOR: filters/http: Slightly update the parsing of chunks
14247 - MINOR: filters/http: Forward remaining data when a channel has no "data" filters
14248 - MINOR: filters: Add an filter example
14249 - MINOR: filters: Extract proxy stuff from the struct filter
14250 - MINOR: map: Add regex matching replacement
14251 - BUG/MINOR: lua: unsafe initialization
14252 - DOC: lua: fix somme errors
14253 - MINOR: lua: file dedicated to unsafe functions
14254 - MINOR: lua: add "now" time function
14255 - MINOR: standard: add RFC HTTP date parser
14256 - MINOR: lua: Add date functions
14257 - MINOR: lua: move common function
14258 - MINOR: lua: merge function
14259 - MINOR: lua: Add concat class
14260 - MINOR: standard: add function "escape_chunk"
14261 - MEDIUM: log: add a new log format flag "E"
14262 - DOC: add server name at rate-limit sessions example
14263 - BUG/MEDIUM: ssl: fix off-by-one in ALPN list allocation
14264 - BUG/MEDIUM: ssl: fix off-by-one in NPN list allocation
14265 - DOC: LUA: fix some typos and syntax errors
14266 - MINOR: cli: add a new "show env" command
14267 - MEDIUM: config: allow to manipulate environment variables in the global section
14268 - MEDIUM: cfgparse: reject incorrect 'timeout retry' keyword spelling in resolvers
14269 - MINOR: mailers: increase default timeout to 10 seconds
14270 - MINOR: mailers: use <CRLF> for all line endings
14271 - BUG/MAJOR: lua: segfault using Concat object
14272 - DOC: lua: copyrights
14273 - MINOR: common: mask conversion
14274 - MEDIUM: dns: extract options
14275 - MEDIUM: dns: add a "resolve-net" option which allow to prefer an ip in a network
14276 - MINOR: mailers: make it possible to configure the connection timeout
14277 - BUG/MAJOR: lua: applets can't sleep.
14278 - BUG/MINOR: server: some prototypes are renamed
14279 - BUG/MINOR: lua: Useless copy
14280 - BUG/MEDIUM: stats: stats bind-process doesn't propagate the process mask correctly
14281 - BUG/MINOR: server: fix the format of the warning on address change
14282 - CLEANUP: server: add "const" to some message strings
14283 - MINOR: server: generalize the "updater" source
14284 - BUG/MEDIUM: chunks: always reject negative-length chunks
14285 - BUG/MINOR: systemd: ensure we don't miss signals
14286 - BUG/MINOR: systemd: report the correct signal in debug message output
14287 - BUG/MINOR: systemd: propagate the correct signal to haproxy
14288 - MINOR: systemd: ensure a reload doesn't mask a stop
14289 - BUG/MEDIUM: cfgparse: wrong argument offset after parsing server "sni" keyword
14290 - CLEANUP: stats: Avoid computation with uninitialized bits.
14291 - CLEANUP: pattern: Ignore unknown samples in pat_match_ip().
14292 - CLEANUP: map: Avoid memory leak in out-of-memory condition.
14293 - BUG/MINOR: tcpcheck: fix incorrect list usage resulting in failure to load certain configs
14294 - BUG/MAJOR: samples: check smp->strm before using it
14295 - MINOR: sample: add a new helper to initialize the owner of a sample
14296 - MINOR: sample: always set a new sample's owner before evaluating it
14297 - BUG/MAJOR: vars: always retrieve the stream and session from the sample
14298 - CLEANUP: payload: remove useless and confusing nullity checks for channel buffer
14299 - BUG/MINOR: ssl: fix usage of the various sample fetch functions
14300 - MINOR: stats: create fields types suitable for all CSV output data
14301 - MINOR: stats: add all the "show info" fields in a table
14302 - MEDIUM: stats: fill all the show info elements prior to displaying them
14303 - MINOR: stats: add a function to emit fields into a chunk
14304 - MINOR: stats: add stats_dump_info_fields() to dump one field per line
14305 - MEDIUM: stats: make use of stats_dump_info_fields() for "show info"
14306 - MINOR: stats: add a declaration of all stats fields
14307 - MINOR: stats: don't hard-code the CSV fields list anymore
14308 - MINOR: stats: create stats fields storage and CSV dump function
14309 - MEDIUM: stats: convert stats_dump_fe_stats() to use stats_dump_fields_csv()
14310 - MEDIUM: stats: make stats_dump_fe_stats() use stats fields for HTML dump
14311 - MEDIUM: stats: convert stats_dump_li_stats() to use stats_dump_fields_csv()
14312 - MEDIUM: stats: make stats_dump_li_stats() use stats fields for HTML dump
14313 - MEDIUM: stats: convert stats_dump_be_stats() to use stats_dump_fields_csv()
14314 - MEDIUM: stats: make stats_dump_be_stats() use stats fields for HTML dump
14315 - MEDIUM: stats: convert stats_dump_sv_stats() to use stats_dump_fields_csv()
14316 - MEDIUM: stats: make stats_dump_sv_stats() use the stats field for HTML
14317 - MEDIUM: stats: move the server state coloring logic to the server dump function
14318 - MINOR: stats: do not use srv->admin & STATS_ADMF_MAINT in HTML dumps
14319 - MINOR: stats: do not check srv->state for SRV_ST_STOPPED in HTML dumps
14320 - MINOR: stats: make CSV report server check status only when enabled
14321 - MINOR: stats: only report backend's down time if it has servers
14322 - MINOR: stats: prepend '*' in front of the check status when in progress
14323 - MINOR: stats: make HTML stats dump rely on the table for the check status
14324 - MINOR: stats: add agent_status, agent_code, agent_duration to output
14325 - MINOR: stats: add check_desc and agent_desc to the output fields
14326 - MINOR: stats: add check and agent's health values in the output
14327 - MEDIUM: stats: make the HTML server state dump use the CSV states
14328 - MEDIUM: stats: only report observe errors when observe is set
14329 - MEDIUM: stats: expose the same flags for CLI and HTTP accesses
14330 - MEDIUM: stats: report server's address in the CSV output
14331 - MEDIUM: stats: report the cookie value in the server & backend CSV dumps
14332 - MEDIUM: stats: compute the color code only in the HTML form
14333 - MEDIUM: stats: report the listeners' address in the CSV output
14334 - MEDIUM: stats: make it possible to report the WAITING state for listeners
14335 - REORG: stats: dump the frontend's HTML stats via a generic function
14336 - REORG: stats: dump the socket stats via the generic function
14337 - REORG: stats: dump the server stats via the generic function
14338 - REORG: stats: dump the backend stats via the generic function
14339 - MEDIUM: stats: add a new "mode" column to report the proxy mode
14340 - MINOR: stats: report the load balancing algorithm in CSV output
14341 - MINOR: stats: add 3 fields to report the frontend-specific connection stats
14342 - MINOR: stats: report number of intercepted requests for frontend and backends
14343 - MINOR: stats: introduce stats_dump_one_line() to dump one stats line
14344 - CLEANUP: stats: make stats_dump_fields_html() not rely on proxy anymore
14345 - MINOR: stats: add ST_SHOWADMIN to pass the admin info in the regular flags
14346 - MINOR: stats: make stats_dump_fields_html() not use &trash by default
14347 - MINOR: stats: add functions to emit typed fields into a chunk
14348 - MEDIUM: stats: support "show info typed" on the CLI
14349 - MEDIUM: stats: implement a typed output format for stats
14350 - DOC: document the "show info typed" and "show stat typed" output formats
14351 - MINOR: cfgparse: warn when uid parameter is not a number
14352 - MINOR: cfgparse: warn when gid parameter is not a number
14353 - BUG/MINOR: standard: Avoid free of non-allocated pointer
14354 - BUG/MINOR: pattern: Avoid memory leak on out-of-memory condition
14355 - CLEANUP: http: fix a build warning introduced by a recent fix
14356 - BUG/MINOR: log: GMT offset not updated when entering/leaving DST
14357
Willy Tarreaucb928252015-12-20 23:33:18 +0100143582015/12/20 : 1.7-dev1
14359 - DOC: specify that stats socket doc (section 9.2) is in management
14360 - BUILD: install only relevant and existing documentation
14361 - CLEANUP: don't ignore debian/ directory if present
14362 - BUG/MINOR: dns: parsing error of some DNS response
14363 - BUG/MEDIUM: namespaces: don't fail if no namespace is used
14364 - BUG/MAJOR: ssl: free the generated SSL_CTX if the LRU cache is disabled
14365 - MEDIUM: dns: Don't use the ANY query type
14366 - BUILD: ssl: fix build error introduced in commit 7969a3 with OpenSSL < 1.0.0
14367 - DOC: fix a typo for a "deviceatlas" keyword
14368 - FIX: small typo in an example using the "Referer" header
14369 - MINOR: cli: ability to set per-server maxconn
14370 - DEBUG/MINOR: memory: add a build option to disable memory pools sharing
14371 - DEBUG/MEDIUM: memory: optionally protect free data in pools
14372 - DEBUG/MEDIUM: memory: add optional control pool memory operations
14373 - MEDIUM: memory: add accounting for failed allocations
14374 - BUG/MEDIUM: config: count memory limits on 64 bits, not 32
14375 - BUG/MAJOR: dns: first DNS response packet not matching queried hostname may lead to a loop
14376 - BUG/MINOR: dns: unable to parse CNAMEs response
14377 - BUG/MINOR: examples/haproxy.init: missing brace in quiet_check()
14378 - DOC: deviceatlas: more example use cases.
14379 - MINOR: config: allow IPv6 bracketed literals
14380 - BUG/BUILD: replace haproxy-systemd-wrapper with $(EXTRA) in install-bin.
14381 - BUILD: add Haiku as supported target.
14382 - BUG/MAJOR: http: don't requeue an idle connection that is already queued
14383 - DOC: typo on capture.res.hdr and capture.req.hdr
14384 - BUG/MINOR: dns: check for duplicate nameserver id in a resolvers section was missing
14385 - CLEANUP: use direction names in place of numeric values
14386 - BUG/MEDIUM: lua: sample fetches based on response doesn't work
14387 - MINOR: check: add agent-send server parameter
14388 - BUG/MINOR: http rule: http capture 'id' rule points to a non existing id
14389 - BUG/MINOR: server: check return value of fgets() in apply_server_state()
14390 - BUG/MINOR: acl: don't use record layer in req_ssl_ver
14391 - BUILD: freebsd: double declaration
14392 - BUG/MEDIUM: lua: clean output buffer
14393 - BUILD: check for libressl to be able to build against it
14394 - DOC: lua-api/index.rst small example fixes, spelling correction.
14395 - DOC: lua: architecture and first steps
14396 - DOC: relation between timeout http-request and option http-buffer-request
14397 - BUILD: Make deviceatlas require PCRE
14398 - BUG: http: do not abort keep-alive connections on server timeout
14399 - BUG/MEDIUM: http: switch the request channel to no-delay once done.
14400 - BUG/MINOR: lua: don't force-sslv3 LUA's SSL socket
14401 - BUILD/MINOR: http: proto_http.h needs sample.h
14402 - BUG/MEDIUM: http: don't enable auto-close on the response side
14403 - BUG/MEDIUM: stream: fix half-closed timeout handling
14404 - CLEANUP: compression: don't allocate DEFAULT_MAXZLIBMEM without USE_ZLIB
14405 - BUG/MEDIUM: cli: changing compression rate-limiting must require admin level
14406 - BUG/MEDIUM: sample: urlp can't match an empty value
14407 - BUILD: dumpstats: silencing warning for printf format specifier / time_t
14408 - CLEANUP: proxy: calloc call inverted arguments
14409 - MINOR: da: silent logging by default and displaying DeviceAtlas support if built.
14410 - BUG/MEDIUM: da: stop DeviceAtlas processing in the convertor if there is no input.
14411 - DOC: Edited 51Degrees section of README/
14412 - BUG/MEDIUM: checks: email-alert not working when declared in defaults
14413 - BUG/MINOR: checks: email-alert causes a segfault when an unknown mailers section is configured
14414 - BUG/MINOR: checks: typo in an email-alert error message
14415 - BUG/MINOR: tcpcheck: conf parsing error when no port configured on server and last rule is a CONNECT with no port
14416 - BUG/MINOR: tcpcheck: conf parsing error when no port configured on server and first rule(s) is (are) COMMENT
14417 - BUG/MEDIUM: http: fix http-reuse when frontend and backend differ
14418 - DOC: prefer using http-request/response over reqXXX/rspXXX directives
14419 - CLEANUP: haproxy: using _GNU_SOURCE instead of __USE_GNU macro.
14420 - MINOR: ssl: Added cert_key_and_chain struct
14421 - MEDIUM: ssl: Added support for creating SSL_CTX with multiple certs
14422 - MINOR: ssl: Added multi cert support for crt-list config keyword
14423 - MEDIUM: ssl: Added multi cert support for loading crt directories
14424 - MEDIUM: ssl: Added support for Multi-Cert OCSP Stapling
14425 - BUILD: ssl: set SSL_SOCK_NUM_KEYTYPES with openssl < 1.0.2
14426 - MINOR: config: make tune.recv_enough configurable
14427 - BUG/MEDIUM: config: properly adjust maxconn with nbproc when memmax is forced
14428 - DOC: ssl: Adding docs for Multi-Cert bundling
14429 - BUG/MEDIUM: peers: table entries learned from a remote are pushed to others after a random delay.
14430 - BUG/MEDIUM: peers: old stick table updates could be repushed.
14431 - MINOR: lua: service/applet can have access to the HTTP headers when a POST is received
14432 - REORG/MINOR: lua: convert boolean "int" to bitfield
14433 - BUG/MEDIUM: lua: Lua applets must not fetch samples using http_txn
14434 - BUG/MINOR: lua: Lua applets must not use http_txn
14435 - BUG/MEDIUM: lua: Forbid HTTP applets from being called from tcp rulesets
14436 - BUG/MAJOR: lua: Do not force the HTTP analysers in use-services
14437 - CLEANUP: lua: bad error messages
14438 - CONTRIB: initiate a debugging suite to make debugging easier
14439
Willy Tarreau991b4782015-10-13 21:48:10 +0200144402015/10/13 : 1.7-dev0
14441 - exact copy of 1.6.0
14442
Willy Tarreau844028b2015-10-13 18:52:22 +0200144432015/10/13 : 1.6.0
14444 - BUG/MINOR: Handle interactive mode in cli handler
14445 - DOC: global section missing parameters
14446 - DOC: backend section missing parameters
14447 - DOC: stats paramaters available in frontend
14448 - MINOR: lru: do not allocate useless memory in lru64_lookup
14449 - BUG/MINOR: http: Add OPTIONS in supported http methods (found by find_http_meth)
14450 - BUG/MINOR: ssl: fix management of the cache where forged certificates are stored
14451 - MINOR: ssl: Release Servers SSL context when HAProxy is shut down
14452 - MINOR: ssl: Read the file used to generate certificates in any order
14453 - MINOR: ssl: Add support for EC for the CA used to sign generated certificates
14454 - MINOR: ssl: Add callbacks to set DH/ECDH params for generated certificates
14455 - BUG/MEDIUM: logs: fix time zone offset format in RFC5424
14456 - BUILD: Fix the build on OSX (htonll/ntohll)
14457 - BUILD: enable build on Linux/s390x
14458 - BUG/MEDIUM: lua: direction test failed
14459 - MINOR: lua: fix a spelling error in some error messages
14460 - CLEANUP: cli: ensure we can never double-free error messages
14461 - BUG/MEDIUM: lua: force server-close mode on Lua services
14462 - MEDIUM: init: support more command line arguments after pid list
14463 - MEDIUM: init: support a list of files on the command line
14464 - MINOR: debug: enable memory poisonning to use byte 0
14465 - BUILD: ssl: fix build error introduced by recent commit
14466 - BUG/MINOR: config: make the stats socket pass the correct proxy to the parsers
14467 - MEDIUM: server: implement TCP_USER_TIMEOUT on the server
14468 - DOC: mention the "namespace" options for bind and server lines
14469 - DOC: add the "management" documentation
14470 - DOC: move the stats socket documentation from config to management
14471 - MINOR: examples: update haproxy.spec to mention new docs
14472 - DOC: mention management.txt in README
14473 - DOC: remove haproxy-{en,fr}.txt
14474 - BUILD: properly report when USE_ZLIB and USE_SLZ are used together
14475 - MINOR: init: report use of libslz instead of "no compression"
14476 - CLEANUP: examples: remove some obsolete and confusing files
14477 - CLEANUP: examples: remove obsolete configuration file samples
14478 - CLEANUP: examples: fix the example file content-sw-sample.cfg
14479 - CLEANUP: examples: update sample file option-http_proxy.cfg
14480 - CLEANUP: examples: update sample file ssl.cfg
14481 - CLEANUP: tests: move a test file from examples/ to tests/
14482 - CLEANUP: examples: shut up warnings in transparent proxy example
14483 - CLEANUP: tests: removed completely obsolete test files
14484 - DOC: update ROADMAP to remove what was done in 1.6
14485 - BUG/MEDIUM: pattern: fixup use_after_free in the pat_ref_delete_by_id
14486
Willy Tarreau8c1ad712015-10-06 12:13:56 +0200144872015/10/06 : 1.6-dev7
14488 - MINOR: cli: Dump all resolvers stats if no resolver section is given
14489 - BUG: config: external-check command validation is checking for incorrect arguments.
14490 - DOC: documentation format cleanups
14491 - DOC: lua: few typos.
14492 - BUG/MEDIUM: str2ip: make getaddrinfo() consider local address selection policy
14493 - BUG/MEDIUM: logs: segfault writing to log from Lua
14494 - DOC: fix lua use-service example
14495 - MINOR: payload: add support for tls session ticket ext
14496 - MINOR: lua: remove the run flag
14497 - MEDIUM: lua: change the timeout execution
14498 - MINOR: lua: rename the tune.lua.applet-timeout
14499 - DOC: lua: update Lua doc
14500 - DOC: lua: update doc according with the last Lua changes
14501 - MINOR: http/tcp: fill the avalaible actions
14502 - DOC: reorder misplaced res.ssl_hello_type in the doc
14503 - BUG/MINOR: tcp: make silent-drop always force a TCP reset
14504 - CLEANUP: tcp: silent-drop: only drain the connection when quick-ack is disabled
14505 - BUILD: tcp: use IPPROTO_IP when SOL_IP is not available
14506 - BUILD: server: fix build warnings introduced by load-server-state
14507 - BUG/MEDIUM: server: fix misuse of format string in load-server-state's warnings
14508
Willy Tarreaue7ae6562015-09-28 23:46:27 +0200145092015/09/28 : 1.6-dev6
14510 - BUG/MAJOR: can't enable a server through the stat socket
14511 - MINOR: server: Macro definition for server-state
14512 - MINOR: cli: new stats socket command: show servers state
14513 - DOC: stats socket command: show servers state
14514 - MINOR: config: new global directive server-state-base
14515 - DOC: global directive server-state-base
14516 - MINOR: config: new global section directive: server-state-file
14517 - DOC: new global directive: server-state-file
14518 - MINOR: config: new backend directives: load-server-state-from-file and server-state-file-name
14519 - DOC: load-server-state-from-file
14520 - MINOR: init: server state loaded from file
14521 - MINOR: server: startup slowstart task when using seamless reload of HAProxy
14522 - MINOR: cli: new stats socket command: show backend
14523 - DOC: servers state seamless reload example
14524 - BUG: dns: can't connect UDP socket on FreeBSD
14525 - MINOR: cfgparse: New function cfg_unregister_sections()
14526 - MINOR: chunk: New function free_trash_buffers()
14527 - BUG/MEDIUM: main: Freeing a bunch of static pointers
14528 - MINOR: proto_http: Externalisation of previously internal functions
14529 - MINOR: global: Few new struct fields for da module
14530 - MAJOR: da: Update of the DeviceAtlas API module
14531 - DOC: DeviceAtlas new keywords
14532 - DOC: README: DeviceAtlas sample configuration updates
14533 - MEDIUM: log: replace sendto() with sendmsg() in __send_log()
14534 - MEDIUM: log: use a separate buffer for the header and for the message
14535 - MEDIUM: logs: remove the hostname, tag and pid part from the logheader
14536 - MEDIUM: logs: add support for RFC5424 header format per logger
14537 - MEDIUM: logs: add a new RFC5424 log-format for the structured-data
14538 - DOC: mention support for the RFC5424 syslog message format
14539 - MEDIUM: logs: have global.log_send_hostname not contain the trailing space
14540 - MEDIUM: logs: pass the trailing "\n" as an iovec
14541 - BUG/MEDIUM: peers: some table updates are randomly not pushed.
14542 - BUG/MEDIUM: peers: same table updates re-pushed after a re-connect
14543 - BUG/MINOR: fct peer_prepare_ackmsg should not use trash.
14544 - MINOR: http: made CHECK_HTTP_MESSAGE_FIRST accessible to other functions
14545 - MINOR: global: Added new fields for 51Degrees device detection
14546 - DOC: Added more explanation for 51Degrees V3.2
14547 - BUILD: Changed 51Degrees option to support V3.2
14548 - MAJOR: 51d: Upgraded to support 51Degrees V3.2 and new features
14549 - MINOR: 51d: Improved string handling for LRU cache
14550 - DOC: add references to rise/fall for the fastinter explanation
14551 - MINOR: support cpu-map feature through the compile option USE_CPU_AFFINITY on FreeBSD
14552 - BUG/MAJOR: lua: potential unexpected aborts()
14553 - BUG/MINOR: lua: breaks the log message if his size exceed one buffer
14554 - MINOR: action: add private configuration
14555 - MINOR: action: add reference to the original keywork matched for the called parser.
14556 - MINOR: lua: change actions registration
14557 - MEDIUM: proto_http: smp_prefetch_http initialize txn
14558 - MINOR: channel: rename function chn_sess to chn_strm
14559 - CLEANUP: lua: align defines
14560 - MINOR: http: export http_get_path() function
14561 - MINOR: http: export the get_reason() function
14562 - MINOR: http: export function http_msg_analyzer()
14563 - MINOR: http: split initialization
14564 - MINOR: lua: reset pointer after use
14565 - MINOR: lua: identify userdata objects
14566 - MEDIUM: lua: use the function lua_rawset in place of lua_settable
14567 - BUG/MAJOR: lua: segfault after the channel data is modified by some Lua action.
14568 - CLEANUP: lua: use calloc in place of malloc
14569 - BUG/MEDIUM: lua: longjmp function must be unregistered
14570 - BUG/MEDIUM: lua: forces a garbage collection
14571 - BUG/MEDIUM: lua: wakeup task on bad conditions
14572 - MINOR: standard: avoid DNS resolution from the function str2sa_range()
14573 - MINOR: lua: extend socket address to support non-IP families
14574 - MINOR: lua/applet: the cosocket applet should use appctx_wakeup in place of task_wakeup
14575 - BUG/MEDIUM: lua: socket destroy before reading pending data
14576 - MEDIUM: lua: change the GC policy
14577 - OPTIM/MEDIUM: lua: executes the garbage collector only when using cosocket
14578 - BUG/MEDIUM: lua: don't reset undesired flags in hlua_ctx_resume
14579 - MINOR: applet: add init function
14580 - MINOR: applet: add an execution timeout
14581 - MINOR: stream/applet: add use-service action
14582 - MINOR: lua: add AppletTCP class and service
14583 - MINOR: lua: add AppletHTTP class and service
14584 - DOC: lua: some documentation update
14585 - DOC: add the documentation about internal circular lists
14586 - DOC: add a CONTRIBUTING file
14587 - DOC: add a MAINTAINERS file
14588 - BUG/MAJOR: peers: fix a crash when stopping peers on unbound processes
14589 - DOC: update coding-style to reference checkpatch.pl
14590 - BUG/MEDIUM: stick-tables: fix double-decrement of tracked entries
14591 - BUG/MINOR: args: add name for ARGT_VAR
14592 - DOC: add more entries to MAINTAINERS
14593 - DOC: add more entries to MAINTAINERS
14594 - CLEANUP: stream-int: remove obsolete function si_applet_call()
14595 - BUG/MAJOR: cli: do not dereference strm_li()->proto->name
14596 - BUG/MEDIUM: http: do not dereference strm_li(stream)
14597 - BUG/MEDIUM: proxy: do not dereference strm_li(stream)
14598 - BUG/MEDIUM: stream: do not dereference strm_li(stream)
14599 - MINOR: stream-int: use si_release_endpoint() to close idle conns
14600 - BUG/MEDIUM: payload: make req.payload and payload_lv aware of dynamic buffers
14601 - BUG/MEDIUM: acl: always accept match "found"
14602 - MINOR: applet: rename applet_runq to applet_active_queue
14603 - BUG/MAJOR: applet: use a separate run queue to maintain list integrity
14604 - MEDIUM: stream-int: split stream_int_update_conn() into si- and conn-specific parts
14605 - MINOR: stream-int: implement a new stream_int_update() function
14606 - MEDIUM: stream-int: factor out the stream update functions
14607 - MEDIUM: stream-int: call stream_int_update() from si_update()
14608 - MINOR: stream-int: export stream_int_update_*
14609 - MINOR: stream-int: move the applet_pause call out of the stream updates
14610 - MEDIUM: stream-int: clean up the conditions to enable reading in si_conn_wake_cb
14611 - MINOR: stream-int: implement the stream_int_notify() function
14612 - MEDIUM: stream-int: use the same stream notification function for applets and conns
14613 - MEDIUM: stream-int: completely remove stream_int_update_embedded()
14614 - MINOR: stream-int: rename si_applet_done() to si_applet_wake_cb()
14615 - BUG/MEDIUM: applet: fix reporting of broken write situation
14616 - BUG/MINOR: stats: do not call cli_release_handler 3 times
14617 - BUG/MEDIUM: cli: properly handle closed output
14618 - MINOR: cli: do not call the release handler on internal error.
14619 - BUG/MEDIUM: stream-int: avoid double-call to applet->release
14620 - DEBUG: add p_malloc() to return a poisonned memory area
14621 - CLEANUP: lua: remove unneeded memset(0) after calloc()
14622 - MINOR: lua: use the proper applet wakeup mechanism
14623 - BUG/MEDIUM: lua: better fix for the protocol check
14624 - BUG/MEDIUM: lua: properly set the target on the connection
14625 - MEDIUM: actions: pass a new "flags" argument to custom actions
14626 - MEDIUM: actions: add new flag ACT_FLAG_FINAL to notify about last call
14627 - MEDIUM: http: pass ACT_FLAG_FINAL to custom actions
14628 - MEDIUM: lua: only allow actions to yield if not in a final call
14629 - DOC: clarify how to make use of abstract sockets in socat
14630 - CLEANUP: config: make the errorloc/errorfile messages less confusing
14631 - MEDIUM: action: add a new flag ACT_FLAG_FIRST
14632 - BUG/MINOR: config: check that tune.bufsize is always positive
14633 - MEDIUM: config: set tune.maxrewrite to 1024 by default
14634 - DOC: add David Carlier as maintainer of da.c
14635 - DOC: fix some broken unexpected unicode chars in the Lua doc.
14636 - BUG/MEDIUM: proxy: ignore stopped peers
14637 - BUG/MEDIUM: proxy: do not wake stopped proxies' tasks during soft_stop()
14638 - MEDIUM: init: completely deallocate unused peers
14639 - BUG/MEDIUM: tcp: fix inverted condition to call custom actions
14640 - DOC: remove outdated actions lists on tcp-request/response
14641 - MEDIUM: tcp: add new tcp action "silent-drop"
14642 - DOC: add URLs to optional libraries in the README
14643
Willy Tarreaua02e8a62015-09-14 12:23:10 +0200146442015/09/14 : 1.6-dev5
14645 - MINOR: dns: dns_resolution structure update: time_t to unsigned int
14646 - BUG/MEDIUM: dns: DNS resolution doesn't start
14647 - BUG/MAJOR: dns: dns client resolution infinite loop
14648 - MINOR: dns: coding style update
14649 - MINOR: dns: new bitmasks to use against DNS flags
14650 - MINOR: dns: dns_nameserver structure update: new counter for truncated response
14651 - MINOR: dns: New DNS response analysis code: DNS_RESP_TRUNCATED
14652 - MEDIUM: dns: handling of truncated response
14653 - MINOR: DNS client query type failover management
14654 - MINOR: dns: no expected DNS record type found
14655 - MINOR: dns: new flag to report that no IP can be found in a DNS response packet
14656 - BUG/MINOR: DNS request retry counter used for retry only
14657 - DOC: DNS documentation updated
14658 - MEDIUM: actions: remove ACTION_STOP
14659 - BUG/MEDIUM: lua: outgoing connection was broken since 1.6-dev2 (bis)
14660 - BUG/MINOR: lua: last log character truncated.
14661 - CLEANUP: typo: bad indent
14662 - CLEANUP: actions: missplaced includes
14663 - MINOR: build: missing header
14664 - CLEANUP: lua: Merge log functions
14665 - BUG/MAJOR: http: don't manipulate the server connection if it's killed
14666 - BUG/MINOR: http: remove stupid HTTP_METH_NONE entry
14667 - BUG/MAJOR: http: don't call http_send_name_header() after an error
14668 - MEDIUM: tools: make str2sa_range() optionally return the FQDN
14669 - BUG/MINOR: tools: make str2sa_range() report unresolvable addresses
14670 - BUG/MEDIUM: dns: use the correct server hostname when resolving
14671
Willy Tarreau61d301f2015-08-30 00:17:17 +0200146722015/08/30 : 1.6-dev4
14673 - MINOR: log: Add log-format variable %HQ, to log HTTP query strings
14674 - DOC: typo in 'redirect', 302 code meaning
14675 - DOC: typos in tcp-check expect examples
14676 - DOC: resolve-prefer default value and default-server update
14677 - MINOR: DNS counters: increment valid counter
14678 - BUG/MEDIUM: DNS resolution response parsing broken
14679 - MINOR: server: add new SRV_ADMF_CMAINT flag
14680 - MINOR: server SRV_ADMF_CMAINT flag doesn't imply SRV_ADMF_FMAINT
14681 - BUG/MEDIUM: dns: wrong first time DNS resolution
14682 - BUG/MEDIUM: lua: Lua tasks fail to start.
14683 - BUILD: add USE_LUA to BUILD_OPTIONS when it's used
14684 - DOC/MINOR: fix OpenBSD versions where haproxy works
14685 - MINOR: 51d: unable to start haproxy without "51degrees-data-file"
14686 - BUG/MEDIUM: peers: fix wrong message id on stick table updates acknowledgement.
14687 - BUG/MAJOR: peers: fix current table pointer not re-initialized on session release.
14688 - BUILD: ssl: Allow building against libssl without SSLv3.
14689 - DOC: clarify some points about SSL and the proxy protocol
14690 - DOC: mention support for RFC 5077 TLS Ticket extension in starter guide
14691 - BUG/MEDIUM: mailer: DATA part must be terminated with <CRLF>.<CRLF>
14692 - DOC: match several lua configuration option names to those implemented in code
14693 - MINOR cfgparse: Correct the mailer warning text to show the right names to the user
14694 - BUG/MINOR: ssl: TLS Ticket Key rotation broken via socket command
14695 - MINOR: stream: initialize the current_rule field to NULL on stream init
14696 - BUG/MEDIUM: lua: timeout error with converters, wrapper and actions.
14697 - CLEANUP: proto_http: remove useless initialisation
14698 - CLEANUP: http/tcp actions: remove the scope member
14699 - BUG/MINOR: proto_tcp: custom action continue is ignored
14700 - MINOR: proto_tcp: add session in the action prototype
14701 - MINOR: vars: reduce the code size of some wrappers
14702 - MINOR: Move http method enum from proto_http to sample
14703 - MINOR: sample: Add ipv6 to ipv4 and sint to ipv6 casts
14704 - MINOR: sample/proto_tcp: export "smp_fetch_src"
14705 - MEDIUM: cli: rely on the map's output type instead of the sample type
14706 - BUG/MEDIUM: stream: The stream doen't inherit SC from the session
14707 - BUG/MEDIUM: vars: segfault during the configuration parsing
14708 - BUG/MEDIUM: stick-tables: refcount error after copying SC for the session to the stream
14709 - BUG/MEDIUM: lua: bad error processing
14710 - MINOR: samples: rename a struct from sample_storage to sample_data
14711 - MINOR: samples: rename some struct member from "smp" to "data"
14712 - MEDIUM: samples: Use the "struct sample_data" in the "struct sample"
14713 - MINOR: samples: extract the anonymous union and create the union sample_value
14714 - MINOR: samples: rename union from "data" to "u"
14715 - MEDIUM: 51degrees: Adapt the 51Degrees library
14716 - MINOR: samples: data assignation simplification
14717 - MEDIUM: pattern/map: Maps can returns various types
14718 - MINOR: map: The map can return IPv4 and IPv6
14719 - MEDIUM: actions: Merge (http|tcp)-(request|reponse) action structs
14720 - MINOR: actions: Remove the data opaque pointer
14721 - MINOR: lua: use the hlua_rule type in place of opaque type
14722 - MINOR: vars: use the vars types as argument in place of opaque type
14723 - MINOR: proto_http: use an "expr" type in place of generic opaque type.
14724 - MINOR: proto_http: replace generic opaque types by real used types for the actions on thr request line
14725 - MINOR: proto_http: replace generic opaque types by real used types in "http_capture"
14726 - MINOR: proto_http: replace generic opaque types by real used types in "http_capture" by id
14727 - MEDIUM: track-sc: Move the track-sc configuration storage in the union
14728 - MEDIUM: capture: Move the capture configuration storage in the union
14729 - MINOR: actions: add "from" information
14730 - MINOR: actions: remove the mark indicating the last entry in enum
14731 - MINOR: actions: Declare all the embedded actions in the same header file
14732 - MINOR: actions: change actions names
14733 - MEDIUM: actions: Add standard return code for the action API
14734 - MEDIUM: actions: Merge (http|tcp)-(request|reponse) keywords structs
14735 - MINOR: proto_tcp: proto_tcp.h is now useles
14736 - MINOR: actions: mutualise the action keyword lookup
14737 - MEDIUM: actions: Normalize the return code of the configuration parsers
14738 - MINOR: actions: Remove wrappers
14739 - MAJOR: stick-tables: use sample types in place of dedicated types
14740 - MEDIUM: stick-tables: use the sample type names
14741 - MAJOR: stick-tables: remove key storage from the key struct
14742 - MEDIUM: stick-tables: Add GPT0 in the stick tables
14743 - MINOR: stick-tables: Add GPT0 access
14744 - MINOR: stick-tables: Add GPC0 actions
14745 - BUG/MEDIUM: lua: the lua fucntion Channel:close() causes a segfault
14746 - DOC: ssl: missing LF
14747 - MINOR: lua: add core.done() function
14748 - DOC: fix function name
14749 - BUG/MINOR: lua: in some case a sample may remain undefined
14750 - DOC: fix "http_action_set_req_line()" comments
14751 - MINOR: http: Action for manipulating the returned status code.
14752 - MEDIUM: lua: turns txn:close into txn:done
14753 - BUG/MEDIUM: lua: cannot process more Lua hooks after a "done()" function call
14754 - BUILD: link with libdl if needed for Lua support
14755 - CLEANUP: backend: factor out objt_server() in connect_server()
14756 - MEDIUM: backend: don't call si_alloc_conn() when we reuse a valid connection
14757 - MEDIUM: stream-int: simplify si_alloc_conn()
14758 - MINOR: stream-int: add new function si_detach_endpoint()
14759 - MINOR: server: add a list of private idle connections
14760 - MINOR: connection: add a new list member in the connection struct
14761 - MEDIUM: stream-int: queue idle connections at the server
14762 - MINOR: stream-int: make si_idle_conn() only accept valid connections
14763 - MINOR: server: add a list of already used idle connections
14764 - MINOR: connection: add a new flag CO_FL_PRIVATE
14765 - MINOR: config: add new setting "http-reuse"
14766 - MAJOR: backend: initial work towards connection reuse
14767 - MAJOR: backend: improve the connection reuse mechanism
14768 - MEDIUM: backend: implement "http-reuse safe"
14769 - MINOR: server: add a list of safe, already reused idle connections
14770 - MEDIUM: backend: add the "http-reuse aggressive" strategy
14771 - DOC: document the new http-reuse directive
14772 - DOC: internals: document next steps for HTTP connection reuse
14773 - DOC: mention that %ms is left-padded with zeroes.
14774 - MINOR: init: indicate to check 'bind' lines when no listeners were found.
14775 - MAJOR: http: remove references to appsession
14776 - CLEANUP: config: remove appsession initialization
14777 - CLEANUP: appsession: remove appsession.c and sessionhash.c
14778 - CLEANUP: tests: remove sessionhash_test.c and test-cookie-appsess.cfg
14779 - CLEANUP: proxy: remove last references to appsession
14780 - CLEANUP: appsession: remove the last include files
14781 - DOC: remove documentation about appsession
14782 - CLEANUP: .gitignore: ignore more test files
14783 - CLEANUP: .gitignore: finally ignore everything but what is known.
14784 - MEDIUM: config: emit a warning on a frontend without listener
14785 - DOC: add doc/internals/entities-v2.txt
14786 - DOC: add doc/linux-syn-cookies.txt
14787 - DOC: add design thoughts on HTTP/2
14788 - DOC: add some thoughts on connection sharing for HTTP/2
14789 - DOC: add design thoughts on dynamic buffer allocation
14790 - BUG/MEDIUM: counters: ensure that src_{inc,clr}_gpc0 creates a missing entry
14791 - DOC: add new file intro.txt
14792 - MAJOR: tproxy: remove support for cttproxy
14793 - BUG/MEDIUM: lua: outgoing connection was broken since 1.6-dev2
14794 - DOC: lua: replace txn:close with txn:done in lua-api
14795 - DOC: intro: minor updates and fixes
14796 - DOC: intro: fix too long line.
14797 - DOC: fix example of http-request using ssl_fc_session_id
14798 - BUG/MEDIUM: lua: txn:done() still causes a segfault in TCP mode
14799 - CLEANUP: lua: fix some indent issues
14800 - BUG/MEDIUM: lua: fix a segfault in txn:done() if called twice
14801 - DOC: lua: mention than txn:close was renamed txn:done.
14802
Willy Tarreau50bdda62015-07-22 17:32:56 +0200148032015/07/22 : 1.6-dev3
14804 - CLEANUP: sample: generalize sample_fetch_string() as sample_fetch_as_type()
14805 - MEDIUM: http: Add new 'set-src' option to http-request
14806 - DOC usesrc root privileges requirments
14807 - BUG/MINOR: dns: wrong time unit for some DNS default parameters
14808 - MINOR: proxy: bit field for proxy_find_best_match diff status
14809 - MINOR: server: new server flag: SRV_F_FORCED_ID
14810 - MINOR: server: server_find functions: id, name, best_match
14811 - DOC: dns: fix chapters syntax
14812 - BUILD/MINOR: tools: rename popcount to my_popcountl
14813 - BUILD: add netbsd TARGET
14814 - MEDIUM: 51Degrees code refactoring and cleanup
14815 - MEDIUM: 51d: add LRU-based cache on User-Agent string detection
14816 - DOC: add notes about the "51degrees-cache-size" parameter
14817 - BUG/MEDIUM: 51d: possible incorrect operations on smp->data.str.str
14818 - BUG/MAJOR: connection: fix TLV offset calculation for proxy protocol v2 parsing
14819 - MINOR: Add sample fetch to detect Supported Elliptic Curves Extension
14820 - BUG/MINOR: payload: Add volatile flag to smp_fetch_req_ssl_ec_ext
14821 - BUG/MINOR: lua: type error in the arguments wrapper
14822 - CLEANUP: vars: remove unused struct
14823 - BUG/MINOR: http/sample: gmtime/localtime can fail
14824 - MINOR: standard: add 64 bits conversion functions
14825 - MAJOR: sample: converts uint and sint in 64 bits signed integer
14826 - MAJOR: arg: converts uint and sint in sint
14827 - MEDIUM: sample: switch to saturated arithmetic
14828 - MINOR: vars: returns variable content
14829 - MEDIUM: vars/sample: operators can use variables as parameter
14830 - BUG/MINOR: ssl: fix smp_fetch_ssl_fc_session_id
14831 - BUILD/MINOR: lua: fix a harmless build warning
14832 - BUILD/MINOR: stats: fix build warning due to condition always true
14833 - BUG/MAJOR: lru: fix unconditional call to free due to unexpected semi-colon
14834 - BUG/MEDIUM: logs: fix improper systematic use of quotes with a few tags
14835 - BUILD/MINOR: lua: ensure that hlua_ctx_destroy is properly defined
14836 - BUG/MEDIUM: lru: fix possible memory leak when ->free() is used
14837 - MINOR: vars: make the accounting not depend on the stream
14838 - MEDIUM: vars: move the session variables to the session, not the stream
14839 - BUG/MEDIUM: vars: do not freeze the connection when the expression cannot be fetched
14840 - BUG/MAJOR: buffers: make the buffer_slow_realign() function respect output data
14841 - BUG/MAJOR: tcp: tcp rulesets were still broken
14842 - MINOR: stats: improve compression stats reporting
14843 - MINOR: ssl: make self-generated certs also work with raw IPv6 addresses
14844 - CLEANUP: ssl: make ssl_sock_generated_cert_serial() take a const
14845 - CLEANUP: ssl: make ssl_sock_generate_certificate() use ssl_sock_generated_cert_serial()
14846 - BUG/MINOR: log: missing some ARGC_* entries in fmt_directives()
14847 - MINOR: args: add new context for servers
14848 - MINOR: stream: maintain consistence between channel_forward and HTTP forward
14849 - MINOR: ssl: provide ia function to set the SNI extension on a connection
14850 - MEDIUM: ssl: add sni support on the server lines
14851 - CLEANUP: stream: remove a useless call to si_detach()
14852 - CLEANUP: stream-int: fix a few outdated comments about stream_int_register_handler()
14853 - CLEANUP: stream-int: remove stream_int_unregister_handler() and si_detach()
14854 - MINOR: stream-int: only use si_release_endpoint() to release a connection
14855 - MINOR: standard: provide htonll() and ntohll()
14856 - CLEANUP/MINOR: dns: dns_str_to_dn_label() only needs a const char
14857 - BUG/MAJOR: dns: fix the length of the string to be copied
14858
Willy Tarreauad90f0d2015-06-17 15:53:25 +0200148592015/06/17 : 1.6-dev2
14860 - BUG/MINOR: ssl: Display correct filename in error message
14861 - MEDIUM: logs: Add HTTP request-line log format directives
14862 - BUG/MEDIUM: check: tcpcheck regression introduced by e16c1b3f
14863 - BUG/MINOR: check: fix tcpcheck error message
14864 - MINOR: use an int instead of calling tcpcheck_get_step_id
14865 - MINOR: tcpcheck_rule structure update
14866 - MINOR: include comment in tcpcheck error log
14867 - DOC: tcpcheck comment documentation
14868 - MEDIUM: server: add support for changing a server's address
14869 - MEDIUM: server: change server ip address from stats socket
14870 - MEDIUM: protocol: add minimalist UDP protocol client
14871 - MEDIUM: dns: implement a DNS resolver
14872 - MAJOR: server: add DNS-based server name resolution
14873 - DOC: server name resolution + proto DNS
14874 - MINOR: dns: add DNS statistics
14875 - MEDIUM: http: configurable http result codes for http-request deny
14876 - BUILD: Compile clean when debug options defined
14877 - MINOR: lru: Add the possibility to free data when an item is removed
14878 - MINOR: lru: Add lru64_lookup function
14879 - MEDIUM: ssl: Add options to forge SSL certificates
14880 - MINOR: ssl: Export functions to manipulate generated certificates
14881 - MEDIUM: config: add DeviceAtlas global keywords
14882 - MEDIUM: global: add the DeviceAtlas required elements to struct global
14883 - MEDIUM: sample: add the da-csv converter
14884 - MEDIUM: init: DeviceAtlas initialization
14885 - BUILD: Makefile: add options to build with DeviceAtlas
14886 - DOC: README: explain how to build with DeviceAtlas
14887 - BUG/MEDIUM: http: fix the url_param fetch
14888 - BUG/MEDIUM: init: segfault if global._51d_property_names is not initialized
14889 - MAJOR: peers: peers protocol version 2.0
14890 - MINOR: peers: avoid re-scheduling of pending stick-table's updates still not pushed.
14891 - MEDIUM: peers: re-schedule stick-table's entry for sync when data is modified.
14892 - MEDIUM: peers: support of any stick-table data-types for sync
14893 - BUG/MAJOR: sample: regression on sample cast to stick table types.
14894 - CLEANUP: deinit: remove codes for cleaning p->block_rules
14895 - DOC: Fix L4TOUT typo in documentation
14896 - DOC: set-log-level in Logging section preamble
14897 - BUG/MEDIUM: compat: fix segfault on FreeBSD
14898 - MEDIUM: check: include server address and port in the send-state header
14899 - MEDIUM: backend: Allow redispatch on retry intervals
14900 - MINOR: Add TLS ticket keys reference and use it in the listener struct
14901 - MEDIUM: Add support for updating TLS ticket keys via socket
14902 - DOC: Document new socket commands "show tls-keys" and "set ssl tls-key"
14903 - MINOR: Add sample fetch which identifies if the SSL session has been resumed
14904 - DOC: Update doc about weight, act and bck fields in the statistics
14905 - BUG/MEDIUM: ssl: fix tune.ssl.default-dh-param value being overwritten
14906 - MINOR: ssl: add a destructor to free allocated SSL ressources
14907 - MEDIUM: ssl: add the possibility to use a global DH parameters file
14908 - MEDIUM: ssl: replace standards DH groups with custom ones
14909 - MEDIUM: stats: Add enum srv_stats_state
14910 - MEDIUM: stats: Separate server state and colour in stats
14911 - MEDIUM: stats: Only report drain state in stats if server has SRV_ADMF_DRAIN set
14912 - MEDIUM: stats: Differentiate between DRAIN and DRAIN (agent)
14913 - MEDIUM: Lower priority of email alerts for log-health-checks messages
14914 - MEDIUM: Send email alerts when servers are marked as UP or enter the drain state
14915 - MEDIUM: Document when email-alerts are sent
14916 - BUG/MEDIUM: lua: bad argument number in analyser and in error message
14917 - MEDIUM: lua: automatically converts strings in proxy, tables, server and ip
14918 - BUG/MINOR: utf8: remove compilator warning
14919 - MEDIUM: map: uses HAProxy facilities to store default value
14920 - BUG/MINOR: lua: error in detection of mandatory arguments
14921 - BUG/MINOR: lua: set current proxy as default value if it is possible
14922 - BUG/MEDIUM: http: the action set-{method|path|query|uri} doesn't run.
14923 - BUG/MEDIUM: lua: undetected infinite loop
14924 - BUG/MAJOR: http: don't read past buffer's end in http_replace_value
14925 - BUG/MEDIUM: http: the function "(req|res)-replace-value" doesn't respect the HTTP syntax
14926 - MEDIUM/CLEANUP: http: rewrite and lighten http_transform_header() prototype
14927 - BUILD: lua: it miss the '-ldl' directive
14928 - MEDIUM: http: allows 'R' and 'S' in the protocol alphabet
14929 - MINOR: http: split the function http_action_set_req_line() in two parts
14930 - MINOR: http: split http_transform_header() function in two parts.
14931 - MINOR: http: export function inet_set_tos()
14932 - MINOR: lua: txn: add function set_(loglevel|tos|mark)
14933 - MINOR: lua: create and register HTTP class
14934 - DOC: lua: fix some typos
14935 - MINOR: lua: add log functions
14936 - BUG/MINOR: lua: Fix SSL initialisation
14937 - DOC: lua: some fixes
14938 - MINOR: lua: (req|res)_get_headers return more than one header value
14939 - MINOR: lua: map system integration in Lua
14940 - BUG/MEDIUM: http: functions set-{path,query,method,uri} breaks the HTTP parser
14941 - MINOR: sample: add url_dec converter
14942 - MEDIUM: sample: fill the struct sample with the session, proxy and stream pointers
14943 - MEDIUM: sample change the prototype of sample-fetches and converters functions
14944 - MINOR: sample: fill the struct sample with the options.
14945 - MEDIUM: sample: change the prototype of sample-fetches functions
14946 - MINOR: http: split the url_param in two parts
14947 - CLEANUP: http: bad indentation
14948 - MINOR: http: add body_param fetch
14949 - MEDIUM: http: url-encoded parsing function can run throught wrapped buffer
14950 - DOC: http: req.body_param documentation
14951 - MINOR: proxy: custom capture declaration
14952 - MINOR: capture: add two "capture" converters
14953 - MEDIUM: capture: Allow capture with slot identifier
14954 - MINOR: http: add array of generic pointers in http_res_rules
14955 - MEDIUM: capture: adds http-response capture
14956 - MINOR: common: escape CSV strings
14957 - MEDIUM: stats: escape some strings in the CSV dump
14958 - MINOR: tcp: add custom actions that can continue tcp-(request|response) processing
14959 - MINOR: lua: Lua tcp action are not final action
14960 - DOC: lua: schematics about lua socket organization
14961 - BUG/MINOR: debug: display (null) in place of "meth"
14962 - DOC: mention the "lua action" in documentation
14963 - MINOR: standard: add function that converts signed int to a string
14964 - BUG/MINOR: sample: wrong conversion of signed values
14965 - MEDIUM: sample: Add type any
14966 - MINOR: debug: add a special converter which display its input sample content.
14967 - MINOR: tcp: increase the opaque data array
14968 - MINOR: tcp/http/conf: extends the keyword registration options
14969 - MINOR: build: fix build dependency
14970 - MEDIUM: vars: adds support of variables
14971 - MINOR: vars: adds get and set functions
14972 - MINOR: lua: Variable access
14973 - MINOR: samples: add samples which returns constants
14974 - BUG/MINOR: vars/compil: fix some warnings
14975 - BUILD: add 51degrees options to makefile.
14976 - MINOR: global: add several 51Degrees members to global
14977 - MINOR: config: add 51Degrees config parsing.
14978 - MINOR: init: add 51Degrees initialisation code
14979 - MEDIUM: sample: add fiftyone_degrees converter.
14980 - MEDIUM: deinit: add cleanup for 51Degrees to deinit
14981 - MEDIUM: sample: add trie support to 51Degrees
14982 - DOC: add 51Degrees notes to configuration.txt.
14983 - DOC: add build indications for 51Degrees to README.
14984 - MEDIUM: cfgparse: introduce weak and strong quoting
14985 - BUG/MEDIUM: cfgparse: incorrect memmove in quotes management
14986 - MINOR: cfgparse: remove line size limitation
14987 - MEDIUM: cfgparse: expand environment variables
14988 - BUG/MINOR: cfgparse: fix typo in 'option httplog' error message
14989 - BUG/MEDIUM: cfgparse: segfault when userlist is misused
14990 - CLEANUP: cfgparse: remove reference to 'ruleset' section
14991 - MEDIUM: cfgparse: check section maximum number of arguments
14992 - MEDIUM: cfgparse: max arguments check in the global section
14993 - MEDIUM: cfgparse: check max arguments in the proxies sections
14994 - CLEANUP: stream-int: remove a redundant clearing of the linger_risk flag
14995 - MINOR: connection: make conn_sock_shutw() actually perform the shutdown() call
14996 - MINOR: stream-int: use conn_sock_shutw() to shutdown a connection
14997 - MINOR: connection: perform the call to xprt->shutw() in conn_data_shutw()
14998 - MEDIUM: stream-int: replace xprt->shutw calls with conn_data_shutw()
14999 - MINOR: checks: use conn_data_shutw_hard() instead of call via xprt
15000 - MINOR: connection: implement conn_sock_send()
15001 - MEDIUM: stream-int: make conn_si_send_proxy() use conn_sock_send()
15002 - MEDIUM: connection: make conn_drain() perform more controls
15003 - REORG: connection: move conn_drain() to connection.c and rename it
15004 - CLEANUP: stream-int: remove inclusion of fd.h that is not used anymore
15005 - MEDIUM: channel: don't always set CF_WAKE_WRITE on bi_put*
15006 - CLEANUP: lua: don't use si_ic/si_oc on known stream-ints
15007 - BUG/MEDIUM: peers: correctly configure the client timeout
15008 - MINOR: peers: centralize configuration of the peers frontend
15009 - MINOR: proxy: store the default target into the frontend's configuration
15010 - MEDIUM: stats: use frontend_accept() as the accept function
15011 - MEDIUM: peers: use frontend_accept() instead of peer_accept()
15012 - CLEANUP: listeners: remove unused timeout
15013 - MEDIUM: listener: store the default target per listener
15014 - BUILD: fix automatic inclusion of libdl.
15015 - MEDIUM: lua: implement a simple memory allocator
15016 - MEDIUM: compression: postpone buffer adjustments after compression
15017 - MEDIUM: compression: don't send leading zeroes with chunk size
15018 - BUG/MINOR: compression: consider the expansion factor in init
15019 - MINOR: http: check the algo name "identity" instead of the function pointer
15020 - CLEANUP: compression: statify all algo-specific functions
15021 - MEDIUM: compression: add a distinction between UA- and config- algorithms
15022 - MEDIUM: compression: add new "raw-deflate" compression algorithm
15023 - MEDIUM: compression: split deflate_flush() into flush and finish
15024 - CLEANUP: compression: remove unused reset functions
15025 - MAJOR: compression: integrate support for libslz
15026 - BUG/MEDIUM: http: hdr_cnt would not count any header when called without name
15027 - BUG/MAJOR: http: null-terminate the http actions keywords list
15028 - CLEANUP: lua: remove the unused hlua_sleep memory pool
15029 - BUG/MAJOR: lua: use correct object size when initializing a new converter
15030 - CLEANUP: lua: remove hard-coded sizeof() in object creations and mallocs
15031 - CLEANUP: lua: fix confusing local variable naming in hlua_txn_new()
15032 - CLEANUP: hlua: stop using variable name "s" alternately for hlua_txn and hlua_smp
15033 - CLEANUP: lua: get rid of the last "*ht" for struct hlua_txn.
15034 - CLEANUP: lua: rename last occurrences of "*s" to "*htxn" for hlua_txn
15035 - CLEANUP: lua: rename variable "sc" for struct hlua_smp
15036 - CLEANUP: lua: get rid of the last two "*hs" for hlua_smp
15037 - REORG/MAJOR: session: rename the "session" entity to "stream"
15038 - REORG/MEDIUM: stream: rename stream flags from SN_* to SF_*
15039 - MINOR: session: start to reintroduce struct session
15040 - MEDIUM: stream: allocate the session when a stream is created
15041 - MEDIUM: stream: move the listener's pointer to the session
15042 - MEDIUM: stream: move the frontend's pointer to the session
15043 - MINOR: session: add a pointer to the session's origin
15044 - MEDIUM: session: use the pointer to the origin instead of s->si[0].end
15045 - CLEANUP: sample: remove useless tests in fetch functions for l4 != NULL
15046 - MEDIUM: http: move header captures from http_txn to struct stream
15047 - MINOR: http: create a dedicated pool for http_txn
15048 - MAJOR: http: move http_txn out of struct stream
15049 - MAJOR: sample: don't pass l7 anymore to sample fetch functions
15050 - CLEANUP: lua: remove unused hlua_smp->l7 and hlua_txn->l7
15051 - MEDIUM: http: remove the now useless http_txn from {req/res} rules
15052 - CLEANUP: lua: don't pass http_txn anymore to hlua_request_act_wrapper()
15053 - MAJOR: sample: pass a pointer to the session to each sample fetch function
15054 - MINOR: stream: provide a few helpers to retrieve frontend, listener and origin
15055 - CLEANUP: stream: don't set ->target to the incoming connection anymore
15056 - MINOR: stream: move session initialization before the stream's
15057 - MINOR: session: store the session's accept date
15058 - MINOR: session: don't rely on s->logs.logwait in embryonic sessions
15059 - MINOR: session: implement session_free() and use it everywhere
15060 - MINOR: session: add stick counters to the struct session
15061 - REORG: stktable: move the stkctr_* functions from stream to sticktable
15062 - MEDIUM: streams: support looking up stkctr in the session
15063 - MEDIUM: session: update the session's stick counters upon session_free()
15064 - MEDIUM: proto_tcp: track the session's counters in the connection ruleset
15065 - MAJOR: tcp: make tcp_exec_req_rules() only rely on the session
15066 - MEDIUM: stream: don't call stream_store_counters() in kill_mini_session() nor session_accept()
15067 - MEDIUM: stream: move all the session-specific stuff of stream_accept() earlier
15068 - MAJOR: stream: don't initialize the stream anymore in stream_accept
15069 - MEDIUM: session: remove the task pointer from the session
15070 - REORG: session: move the session parts out of stream.c
15071 - MINOR: stream-int: make appctx_new() take the applet in argument
15072 - MEDIUM: peers: move the appctx initialization earlier
15073 - MINOR: session: introduce session_new()
15074 - MINOR: session: make use of session_new() when creating a new session
15075 - MINOR: peers: make use of session_new() when creating a new session
15076 - MEDIUM: peers: initialize the task before the stream
15077 - MINOR: session: set the CO_FL_CONNECTED flag on the connection once ready
15078 - CLEANUP: stream.c: do not re-attach the connection to the stream
15079 - MEDIUM: stream: isolate connection-specific initialization code
15080 - MEDIUM: stream: also accept appctx as origin in stream_accept_session()
15081 - MEDIUM: peers: make use of stream_accept_session()
15082 - MEDIUM: frontend: make ->accept only return +/-1
15083 - MEDIUM: stream: return the stream upon accept()
15084 - MEDIUM: frontend: move some stream initialisation to stream_new()
15085 - MEDIUM: frontend: move the fd-specific settings to session_accept_fd()
15086 - MEDIUM: frontend: don't restrict frontend_accept() to connections anymore
15087 - MEDIUM: frontend: move some remaining stream settings to stream_new()
15088 - CLEANUP: frontend: remove one useless local variable
15089 - MEDIUM: stream: don't rely on the session's listener anymore in stream_new()
15090 - MEDIUM: lua: make use of stream_new() to create an outgoing connection
15091 - MINOR: lua: minor cleanup in hlua_socket_new()
15092 - MINOR: lua: no need for setting timeouts / conn_retries in hlua_socket_new()
15093 - MINOR: peers: no need for setting timeouts / conn_retries in peer_session_create()
15094 - CLEANUP: stream-int: swap stream-int and appctx declarations
15095 - CLEANUP: namespaces: fix protection against multiple inclusions
15096 - MINOR: session: maintain the session count stats in the session, not the stream
15097 - MEDIUM: session: adjust the connection flags before stream_new()
15098 - MINOR: stream: pass the pointer to the origin explicitly to stream_new()
15099 - CLEANUP: poll: move the conditions for waiting out of the poll functions
15100 - BUG/MEDIUM: listener: don't report an error when resuming unbound listeners
15101 - BUG/MEDIUM: init: don't limit cpu-map to the first 32 processes only
15102 - BUG/MAJOR: tcp/http: fix current_rule assignment when restarting over a ruleset
15103 - BUG/MEDIUM: stream-int: always reset si->ops when si->end is nullified
15104 - DOC: update the entities diagrams
15105 - BUG/MEDIUM: http: properly retrieve the front connection
15106 - MINOR: applet: add a new "owner" pointer in the appctx
15107 - MEDIUM: applet: make the applet not depend on a stream interface anymore
15108 - REORG: applet: move the applet definitions out of stream_interface
15109 - CLEANUP: applet: rename struct si_applet to applet
15110 - REORG: stream-int: create si_applet_ops dedicated to applets
15111 - MEDIUM: applet: add basic support for an applet run queue
15112 - MEDIUM: applet: implement a run queue for active appctx
15113 - MEDIUM: stream-int: add a new function si_applet_done()
15114 - MAJOR: applet: now call si_applet_done() instead of si_update() in I/O handlers
15115 - MAJOR: stream: use a regular ->update for all stream interfaces
15116 - MEDIUM: dumpstats: don't unregister the applet anymore
15117 - MEDIUM: applet: centralize the call to si_applet_done() in the I/O handler
15118 - MAJOR: stream: do not allocate request buffers anymore when the left side is an applet
15119 - MINOR: stream-int: add two flags to indicate an applet's wishes regarding I/O
15120 - MEDIUM: applet: make the applets only use si_applet_{cant|want|stop}_{get|put}
15121 - MEDIUM: stream-int: pause the appctx if the task is woken up
15122 - BUG/MAJOR: tcp: only call registered actions when they're registered
15123 - BUG/MEDIUM: peers: fix applet scheduling
15124 - BUG/MEDIUM: peers: recent applet changes broke peers updates scheduling
15125 - MINOR: tools: provide an rdtsc() function for time comparisons
15126 - IMPORT: lru: import simple ebtree-based LRU functions
15127 - IMPORT: hash: import xxhash-r39
15128 - MEDIUM: pattern: add a revision to all pattern expressions
15129 - MAJOR: pattern: add LRU-based cache on pattern matching
15130 - BUG/MEDIUM: http: remove content-length from chunked messages
15131 - DOC: http: update the comments about the rules for determining transfer-length
15132 - BUG/MEDIUM: http: do not restrict parsing of transfer-encoding to HTTP/1.1
15133 - BUG/MEDIUM: http: incorrect transfer-coding in the request is a bad request
15134 - BUG/MEDIUM: http: remove content-length form responses with bad transfer-encoding
15135 - MEDIUM: http: restrict the HTTP version token to 1 digit as per RFC7230
15136 - MEDIUM: http: disable support for HTTP/0.9 by default
15137 - MEDIUM: http: add option-ignore-probes to get rid of the floods of 408
15138 - BUG/MINOR: config: clear proxy->table.peers.p for disabled proxies
15139 - MEDIUM: init: don't stop proxies in parent process when exiting
15140 - MINOR: stick-table: don't attach to peers in stopped state
15141 - MEDIUM: config: initialize stick-tables after peers, not before
15142 - MEDIUM: peers: add the ability to disable a peers section
15143 - MINOR: peers: store the pointer to the signal handler
15144 - MEDIUM: peers: unregister peers that were never started
15145 - MEDIUM: config: propagate the table's process list to the peers sections
15146 - MEDIUM: init: stop any peers section not bound to the correct process
15147 - MEDIUM: config: validate that peers sections are bound to exactly one process
15148 - MAJOR: peers: allow peers section to be used with nbproc > 1
15149 - DOC: relax the peers restriction to single-process
15150 - DOC: document option http-ignore-probes
15151 - DOC: fix the comments about the meaning of msg->sol in HTTP
15152 - BUG/MEDIUM: http: wait for the exact amount of body bytes in wait_for_request_body
15153 - BUG/MAJOR: http: prevent risk of reading past end with balance url_param
15154 - MEDIUM: stream: move HTTP request body analyser before process_common
15155 - MEDIUM: http: add a new option http-buffer-request
15156 - MEDIUM: http: provide 3 fetches for the body
15157 - DOC: update the doc on the proxy protocol
15158 - BUILD: pattern: fix build warnings introduced in the LRU cache
15159 - BUG/MEDIUM: stats: properly initialize the scope before dumping stats
15160 - CLEANUP: config: fix misleading information in error message.
15161 - MINOR: config: report the number of processes using a peers section in the error case
15162 - BUG/MEDIUM: config: properly compute the default number of processes for a proxy
15163 - MEDIUM: http: add new "capture" action for http-request
15164 - BUG/MEDIUM: http: fix the http-request capture parser
15165 - BUG/MEDIUM: http: don't forward client shutdown without NOLINGER except for tunnels
15166 - BUILD/MINOR: ssl: fix build failure introduced by recent patch
15167 - BUG/MAJOR: check: fix breakage of inverted tcp-check rules
15168 - CLEANUP: checks: fix double usage of cur / current_step in tcp-checks
15169 - BUG/MEDIUM: checks: do not dereference head of a tcp-check at the end
15170 - CLEANUP: checks: simplify the loop processing of tcp-checks
15171 - BUG/MAJOR: checks: always check for end of list before proceeding
15172 - BUG/MEDIUM: checks: do not dereference a list as a tcpcheck struct
15173 - BUG/MAJOR: checks: break infinite loops when tcp-checks starts with comment
15174 - MEDIUM: http: make url_param iterate over multiple occurrences
15175 - BUG/MEDIUM: peers: apply a random reconnection timeout
15176 - MEDIUM: config: reject invalid config with name duplicates
15177 - MEDIUM: config: reject conflicts in table names
15178 - CLEANUP: proxy: make the proxy lookup functions more user-friendly
15179 - MINOR: proxy: simply ignore duplicates in proxy name lookups
15180 - MINOR: config: don't open-code proxy name lookups
15181 - MEDIUM: config: clarify the conflicting modes detection for backend rules
15182 - CLEANUP: proxy: remove now unused function findproxy_mode()
15183 - MEDIUM: stick-table: remove the now duplicate find_stktable() function
15184 - MAJOR: config: remove the deprecated reqsetbe / reqisetbe actions
15185 - MINOR: proxy: add a new function proxy_find_by_id()
15186 - MINOR: proxy: add a flag to memorize that the proxy's ID was forced
15187 - MEDIUM: proxy: add a new proxy_find_best_match() function
15188 - CLEANUP: http: explicitly reference request in http_apply_redirect_rules()
15189 - MINOR: http: prepare support for parsing redirect actions on responses
15190 - MEDIUM: http: implement http-response redirect rules
15191 - MEDIUM: http: no need to close the request on redirect if data was parsed
15192 - BUG/MEDIUM: http: fix body processing for the stats applet
15193 - BUG/MINOR: da: fix log-level comparison to emove annoying warning
15194 - CLEANUP: global: remove one ifdef USE_DEVICEATLAS
15195 - CLEANUP: da: move the converter registration to da.c
15196 - CLEANUP: da: register the config keywords in da.c
15197 - CLEANUP: adjust the envelope name in da.h to reflect the file name
15198 - CLEANUP: da: remove ifdef USE_DEVICEATLAS from da.c
15199 - BUILD: make 51D easier to build by defaulting to 51DEGREES_SRC
15200 - BUILD: fix build warning when not using 51degrees
15201 - BUILD: make DeviceAtlas easier to build by defaulting to DEVICEATLAS_SRC
15202 - BUILD: ssl: fix recent build breakage on older SSL libs
15203
Willy Tarreau8747b6d2015-03-11 23:57:23 +0100152042015/03/11 : 1.6-dev1
15205 - CLEANUP: extract temporary $CFG to eliminate duplication
15206 - CLEANUP: extract temporary $BIN to eliminate duplication
15207 - CLEANUP: extract temporary $PIDFILE to eliminate duplication
15208 - CLEANUP: extract temporary $LOCKFILE to eliminate duplication
15209 - CLEANUP: extract quiet_check() to avoid duplication
15210 - BUG/MINOR: don't start haproxy on reload
15211 - DOC: Address issue where documentation is excluded due to a gitignore rule.
15212 - BUG/MEDIUM: systemd: set KillMode to 'mixed'
15213 - BUILD: fix "make install" to support spaces in the install dirs
15214 - BUG/MINOR: config: http-request replace-header arg typo
15215 - BUG: config: error in http-response replace-header number of arguments
15216 - DOC: missing track-sc* in http-request rules
15217 - BUILD: lua: missing ifdef related to SSL when enabling LUA
15218 - BUG/MEDIUM: regex: fix pcre_study error handling
15219 - MEDIUM: regex: Use pcre_study always when PCRE is used, regardless of JIT
15220 - BUG/MINOR: Fix search for -p argument in systemd wrapper.
15221 - MEDIUM: Improve signal handling in systemd wrapper.
15222 - DOC: fix typo in Unix Socket commands
15223 - BUG/MEDIUM: checks: external checks can't change server status to UP
15224 - BUG/MEDIUM: checks: segfault with external checks in a backend section
15225 - BUG/MINOR: checks: external checks shouldn't wait for timeout to return the result
15226 - BUG/MEDIUM: auth: fix segfault with http-auth and a configuration with an unknown encryption algorithm
15227 - BUG/MEDIUM: config: userlists should ensure that encrypted passwords are supported
15228 - BUG/MINOR: config: don't propagate process binding for dynamic use_backend
15229 - BUG/MINOR: log: fix request flags when keep-alive is enabled
15230 - BUG/MEDIUM: checks: fix conflicts between agent checks and ssl healthchecks
15231 - MINOR: checks: allow external checks in backend sections
15232 - MEDIUM: checks: provide environment variables to the external checks
15233 - MINOR: checks: update dynamic environment variables in external checks
15234 - DOC: checks: environment variables used by "external-check command"
15235 - BUG/MEDIUM: backend: correctly detect the domain when use_domain_only is used
15236 - MINOR: ssl: load certificates in alphabetical order
15237 - BUG/MINOR: checks: prevent http keep-alive with http-check expect
15238 - MINOR: lua: typo in an error message
15239 - MINOR: report the Lua version in -vv
15240 - MINOR: lua: add a compilation error message when compiled with an incompatible version
15241 - BUG/MEDIUM: lua: segfault when calling haproxy sample fetches from lua
15242 - BUILD: try to automatically detect the Lua library name
15243 - BUILD/CLEANUP: systemd: avoid a warning due to mixed code and declaration
15244 - BUG/MEDIUM: backend: Update hash to use unsigned int throughout
15245 - BUG/MEDIUM: connection: fix memory corruption when building a proxy v2 header
15246 - MEDIUM: connection: add new bit in Proxy Protocol V2
15247 - BUG/MINOR: ssl: rejects OCSP response without nextupdate.
15248 - BUG/MEDIUM: ssl: Fix to not serve expired OCSP responses.
15249 - BUG/MINOR: ssl: Fix OCSP resp update fails with the same certificate configured twice.
15250 - BUG/MINOR: ssl: Fix external function in order not to return a pointer on an internal trash buffer.
15251 - MINOR: add fetchs 'ssl_c_der' and 'ssl_f_der' to return DER formatted certs
15252 - MINOR: ssl: add statement to force some ssl options in global.
15253 - BUG/MINOR: ssl: correctly initialize ssl ctx for invalid certificates
15254 - BUG/MEDIUM: ssl: fix bad ssl context init can cause segfault in case of OOM.
15255 - BUG/MINOR: samples: fix unnecessary memcopy converting binary to string.
15256 - MINOR: samples: adds the bytes converter.
15257 - MINOR: samples: adds the field converter.
15258 - MINOR: samples: add the word converter.
15259 - BUG/MINOR: server: move the directive #endif to the end of file
15260 - BUG/MAJOR: buffer: check the space left is enough or not when input data in a buffer is wrapped
15261 - DOC: fix a few typos
15262 - CLEANUP: epoll: epoll_events should be allocated according to global.tune.maxpollevents
15263 - BUG/MINOR: http: fix typo: "401 Unauthorized" => "407 Unauthorized"
15264 - BUG/MINOR: parse: refer curproxy instead of proxy
15265 - BUG/MINOR: parse: check the validity of size string in a more strict way
15266 - BUILD: add new target 'make uninstall' to support uninstalling haproxy from OS
15267 - DOC: expand the docs for the provided stats.
15268 - BUG/MEDIUM: unix: do not unlink() abstract namespace sockets upon failure.
15269 - MEDIUM: ssl: Certificate Transparency support
15270 - MEDIUM: stats: proxied stats admin forms fix
15271 - MEDIUM: http: Compress HTTP responses with status codes 201,202,203 in addition to 200
15272 - BUG/MEDIUM: connection: sanitize PPv2 header length before parsing address information
15273 - MAJOR: namespace: add Linux network namespace support
15274 - MINOR: systemd: Check configuration before start
15275 - BUILD: ssl: handle boringssl in openssl version detection
15276 - BUILD: ssl: disable OCSP when using boringssl
15277 - BUILD: ssl: don't call get_rfc2409_prime when using boringssl
15278 - MINOR: ssl: don't use boringssl's cipher_list
15279 - BUILD: ssl: use OPENSSL_NO_OCSP to detect OCSP support
15280 - MINOR: stats: fix minor typo in HTML page
15281 - MINOR: Also accept SIGHUP/SIGTERM in systemd-wrapper
15282 - MEDIUM: Add support for configurable TLS ticket keys
15283 - DOC: Document the new tls-ticket-keys bind keyword
15284 - DOC: clearly state that the "show sess" output format is not fixed
15285 - MINOR: stats: fix minor typo fix in stats_dump_errors_to_buffer()
15286 - DOC: httplog does not support 'no'
15287 - BUG/MEDIUM: ssl: Fix a memory leak in DHE key exchange
15288 - MINOR: ssl: use SSL_get_ciphers() instead of directly accessing the cipher list.
15289 - BUG/MEDIUM: Consistently use 'check' in process_chk
15290 - MEDIUM: Add external check
15291 - BUG/MEDIUM: Do not set agent health to zero if server is disabled in config
15292 - MEDIUM/BUG: Only explicitly report "DOWN (agent)" if the agent health is zero
15293 - MEDIUM: Remove connect_chk
15294 - MEDIUM: Refactor init_check and move to checks.c
15295 - MEDIUM: Add free_check() helper
15296 - MEDIUM: Move proto and addr fields struct check
15297 - MEDIUM: Attach tcpcheck_rules to check
15298 - MEDIUM: Add parsing of mailers section
15299 - MEDIUM: Allow configuration of email alerts
15300 - MEDIUM: Support sending email alerts
15301 - DOC: Document email alerts
15302 - MINOR: Remove trailing '.' from email alert messages
15303 - MEDIUM: Allow suppression of email alerts by log level
15304 - BUG/MEDIUM: Do not consider an agent check as failed on L7 error
15305 - MINOR: deinit: fix memory leak
15306 - MINOR: http: export the function 'smp_fetch_base32'
15307 - BUG/MEDIUM: http: tarpit timeout is reset
15308 - MINOR: sample: add "json" converter
15309 - BUG/MEDIUM: pattern: don't load more than once a pattern list.
15310 - MINOR: map/acl/dumpstats: remove the "Done." message
15311 - BUG/MAJOR: ns: HAProxy segfault if the cli_conn is not from a network connection
15312 - BUG/MINOR: pattern: error message missing
15313 - BUG/MEDIUM: pattern: some entries are not deleted with case insensitive match
15314 - BUG/MINOR: ARG6 and ARG7 don't fit in a 32 bits word
15315 - MAJOR: poll: only rely on wake_expired_tasks() to compute the wait delay
15316 - MEDIUM: task: call session analyzers if the task is woken by a message.
15317 - MEDIUM: protocol: automatically pick the proto associated to the connection.
15318 - MEDIUM: channel: wake up any request analyzer on response activity
15319 - MINOR: converters: add a "void *private" argument to converters
15320 - MINOR: converters: give the session pointer as converter argument
15321 - MINOR: sample: add private argument to the struct sample_fetch
15322 - MINOR: global: export function and permits to not resolve DNS names
15323 - MINOR: sample: add function for browsing samples.
15324 - MINOR: global: export many symbols.
15325 - MINOR: includes: fix a lot of missing or useless includes
15326 - MEDIUM: tcp: add register keyword system.
15327 - MEDIUM: buffer: make bo_putblk/bo_putstr/bo_putchk return the number of bytes copied.
15328 - MEDIUM: http: change the code returned by the response processing rule functions
15329 - MEDIUM: http/tcp: permit to resume http and tcp custom actions
15330 - MINOR: channel: functions to get data from a buffer without copy
15331 - MEDIUM: lua: lua integration in the build and init system.
15332 - MINOR: lua: add ease functions
15333 - MINOR: lua: add runtime execution context
15334 - MEDIUM: lua: "com" signals
15335 - MINOR: lua: add the configuration directive "lua-load"
15336 - MINOR: lua: core: create "core" class and object
15337 - MINOR: lua: post initialisation bindings
15338 - MEDIUM: lua: add coroutine as tasks.
15339 - MINOR: lua: add sample and args type converters
15340 - MINOR: lua: txn: create class TXN associated with the transaction.
15341 - MINOR: lua: add shared context in the lua stack
15342 - MINOR: lua: txn: import existing sample-fetches in the class TXN
15343 - MINOR: lua: txn: add lua function in TXN that returns an array of http headers
15344 - MINOR: lua: register and execute sample-fetches in LUA
15345 - MINOR: lua: register and execute converters in LUA
15346 - MINOR: lua: add bindings for tcp and http actions
15347 - MINOR: lua: core: add sleep functions
15348 - MEDIUM: lua: socket: add "socket" class for TCP I/O
15349 - MINOR: lua: core: pattern and acl manipulation
15350 - MINOR: lua: channel: add "channel" class
15351 - MINOR: lua: txn: object "txn" provides two objects "channel"
15352 - MINOR: lua: core: can set the nice of the current task
15353 - MINOR: lua: core: can yield an execution stack
15354 - MINOR: lua: txn: add binding for closing the client connection.
15355 - MEDIUM: lua: Lua initialisation "on demand"
15356 - BUG/MAJOR: lua: send function fails and return bad bytes
15357 - MINOR: remove unused declaration.
15358 - MINOR: lua: remove some #define
15359 - MINOR: lua: use bitfield and macro in place of integer and enum
15360 - MINOR: lua: set skeleton for Lua execution expiration
15361 - MEDIUM: lua: each yielding function returns a wake up time.
15362 - MINOR: lua: adds "forced yield" flag
15363 - MEDIUM: lua: interrupt the Lua execution for running other process
15364 - MEDIUM: lua: change the sleep function core
15365 - BUG/MEDIUM: lua: the execution timeout is ignored in yield case
15366 - DOC: lua: Lua configuration documentation
15367 - MINOR: lua: add the struct session in the lua channel struct
15368 - BUG/MINOR: lua: set buffer if it is nnot avalaible.
15369 - BUG/MEDIUM: lua: reset flags before resuming execution
15370 - BUG/MEDIUM: lua: fix infinite loop about channel
15371 - BUG/MEDIUM: lua: the Lua process is not waked up after sending data on requests side
15372 - BUG/MEDIUM: lua: many errors when we try to send data with the channel API
15373 - MEDIUM: lua: use the Lua-5.3 version of the library
15374 - BUG/MAJOR: lua: some function are not yieldable, the forced yield causes errors
15375 - BUG/MEDIUM: lua: can't handle the response bytes
15376 - BUG/MEDIUM: lua: segfault with buffer_replace2
15377 - BUG/MINOR: lua: check buffers before initializing socket
15378 - BUG/MINOR: log: segfault if there are no proxy reference
15379 - BUG/MEDIUM: lua: sockets don't have buffer to write data
15380 - BUG/MEDIUM: lua: cannot connect socket
15381 - BUG/MINOR: lua: sockets receive behavior doesn't follows the specs
15382 - BUG/BUILD: lua: The strict Lua 5.3 version check is not done.
15383 - BUG/MEDIUM: buffer: one byte miss in buffer free space check
15384 - MEDIUM: lua: make the functions hlua_gethlua() and hlua_sethlua() faster
15385 - MINOR: replace the Core object by a simple model.
15386 - MEDIUM: lua: change the objects configuration
15387 - MEDIUM: lua: create a namespace for the fetches
15388 - MINOR: converters: add function to browse converters
15389 - MINOR: lua: wrapper for converters
15390 - MINOR: lua: replace function (req|get)_channel by a variable
15391 - MINOR: lua: fetches and converters can return an empty string in place of nil
15392 - DOC: lua api
15393 - BUG/MEDIUM: sample: fix random number upper-bound
15394 - BUG/MINOR: stats:Fix incorrect printf type.
15395 - BUG/MAJOR: session: revert all the crappy client-side timeout changes
15396 - BUG/MINOR: logs: properly initialize and count log sockets
15397 - BUG/MEDIUM: http: fetch "base" is not compatible with set-header
15398 - BUG/MINOR: counters: do not untrack counters before logging
15399 - BUG/MAJOR: sample: correctly reinitialize sample fetch context before calling sample_process()
15400 - MINOR: stick-table: make stktable_fetch_key() indicate why it failed
15401 - BUG/MEDIUM: counters: fix track-sc* to wait on unstable contents
15402 - BUILD: remove TODO from the spec file and add README
15403 - MINOR: log: make MAX_SYSLOG_LEN overridable at build time
15404 - MEDIUM: log: support a user-configurable max log line length
15405 - DOC: provide an example of how to use ssl_c_sha1
15406 - BUILD: checks: external checker needs signal.h
15407 - BUILD: checks: kill a minor warning on Solaris in external checks
15408 - BUILD: http: fix isdigit & isspace warnings on Solaris
15409 - BUG/MINOR: listener: set the listener's fd to -1 after deletion
15410 - BUG/MEDIUM: unix: failed abstract socket binding is retryable
15411 - MEDIUM: listener: implement a per-protocol pause() function
15412 - MEDIUM: listener: support rebinding during resume()
15413 - BUG/MEDIUM: unix: completely unbind abstract sockets during a pause()
15414 - DOC: explicitly mention the limits of abstract namespace sockets
15415 - DOC: minor fix on {sc,src}_kbytes_{in,out}
15416 - DOC: fix alphabetical sort of converters
15417 - MEDIUM: stick-table: implement lookup from a sample fetch
15418 - MEDIUM: stick-table: add new converters to fetch table data
15419 - MINOR: samples: add two converters for the date format
15420 - BUG/MAJOR: http: correctly rewind the request body after start of forwarding
15421 - DOC: remove references to CPU=native in the README
15422 - DOC: mention that "compression offload" is ignored in defaults section
15423 - DOC: mention that Squid correctly responds 400 to PPv2 header
15424 - BUILD: fix dependencies between config and compat.h
15425 - MINOR: session: export the function 'smp_fetch_sc_stkctr'
15426 - MEDIUM: stick-table: make it easier to register extra data types
15427 - BUG/MINOR: http: base32+src should use the big endian version of base32
15428 - MINOR: sample: allow IP address to cast to binary
15429 - MINOR: sample: add new converters to hash input
15430 - MINOR: sample: allow integers to cast to binary
15431 - BUILD: report commit ID in git versions as well
15432 - CLEANUP: session: move the stick counters declarations to stick_table.h
15433 - MEDIUM: http: add the track-sc* actions to http-request rules
15434 - BUG/MEDIUM: connection: fix proxy v2 header again!
15435 - BUG/MAJOR: tcp: fix a possible busy spinning loop in content track-sc*
15436 - OPTIM/MINOR: proxy: reduce struct proxy by 48 bytes on 64-bit archs
15437 - MINOR: log: add a new field "%lc" to implement a per-frontend log counter
15438 - BUG/MEDIUM: http: fix inverted condition in pat_match_meth()
15439 - BUG/MEDIUM: http: fix improper parsing of HTTP methods for use with ACLs
15440 - BUG/MINOR: pattern: remove useless allocation of unused trash in pat_parse_reg()
15441 - BUG/MEDIUM: acl: correctly compute the output type when a converter is used
15442 - CLEANUP: acl: cleanup some of the redundancy and spaghetti after last fix
15443 - BUG/CRITICAL: http: don't update msg->sov once data start to leave the buffer
15444 - MEDIUM: http: enable header manipulation for 101 responses
15445 - BUG/MEDIUM: config: propagate frontend to backend process binding again.
15446 - MEDIUM: config: properly propagate process binding between proxies
15447 - MEDIUM: config: make the frontends automatically bind to the listeners' processes
15448 - MEDIUM: config: compute the exact bind-process before listener's maxaccept
15449 - MEDIUM: config: only warn if stats are attached to multi-process bind directives
15450 - MEDIUM: config: report it when tcp-request rules are misplaced
15451 - DOC: indicate in the doc that track-sc* can wait if data are missing
15452 - MINOR: config: detect the case where a tcp-request content rule has no inspect-delay
15453 - MEDIUM: systemd-wrapper: support multiple executable versions and names
15454 - BUG/MEDIUM: remove debugging code from systemd-wrapper
15455 - BUG/MEDIUM: http: adjust close mode when switching to backend
15456 - BUG/MINOR: config: don't propagate process binding on fatal errors.
15457 - BUG/MEDIUM: check: rule-less tcp-check must detect connect failures
15458 - BUG/MINOR: tcp-check: report the correct failed step in the status
15459 - DOC: indicate that weight zero is reported as DRAIN
15460 - BUG/MEDIUM: config: avoid skipping disabled proxies
15461 - BUG/MINOR: config: do not accept more track-sc than configured
15462 - BUG/MEDIUM: backend: fix URI hash when a query string is present
15463 - BUG/MEDIUM: http: don't dump debug headers on MSG_ERROR
15464 - BUG/MAJOR: cli: explicitly call cli_release_handler() upon error
15465 - BUG/MEDIUM: tcp: fix outgoing polling based on proxy protocol
15466 - BUILD/MINOR: ssl: de-constify "ciphers" to avoid a warning on openssl-0.9.8
15467 - BUG/MEDIUM: tcp: don't use SO_ORIGINAL_DST on non-AF_INET sockets
15468 - BUG/BUILD: revert accidental change in the makefile from latest SSL fix
15469 - BUG/MEDIUM: ssl: force a full GC in case of memory shortage
15470 - MEDIUM: ssl: add support for smaller SSL records
15471 - MINOR: session: release a few other pools when stopping
15472 - MINOR: task: release the task pool when stopping
15473 - BUG/MINOR: config: don't inherit the default balance algorithm in frontends
15474 - BUG/MAJOR: frontend: initialize capture pointers earlier
15475 - BUG/MINOR: stats: correctly set the request/response analysers
15476 - MAJOR: polling: centralize calls to I/O callbacks
15477 - DOC: fix typo in the body parser documentation for msg.sov
15478 - BUG/MINOR: peers: the buffer size is global.tune.bufsize, not trash.size
15479 - MINOR: sample: add a few basic internal fetches (nbproc, proc, stopping)
15480 - DEBUG: pools: apply poisonning on every allocated pool
15481 - BUG/MAJOR: sessions: unlink session from list on out of memory
15482 - BUG/MEDIUM: patterns: previous fix was incomplete
15483 - BUG/MEDIUM: payload: ensure that a request channel is available
15484 - BUG/MINOR: tcp-check: don't condition data polling on check type
15485 - BUG/MEDIUM: tcp-check: don't rely on random memory contents
15486 - BUG/MEDIUM: tcp-checks: disable quick-ack unless next rule is an expect
15487 - BUG/MINOR: config: fix typo in condition when propagating process binding
15488 - BUG/MEDIUM: config: do not propagate processes between stopped processes
15489 - BUG/MAJOR: stream-int: properly check the memory allocation return
15490 - BUG/MEDIUM: memory: fix freeing logic in pool_gc2()
15491 - BUG/MAJOR: namespaces: conn->target is not necessarily a server
15492 - BUG/MEDIUM: compression: correctly report zlib_mem
15493 - CLEANUP: lists: remove dead code
15494 - CLEANUP: memory: remove dead code
15495 - CLEANUP: memory: replace macros pool_alloc2/pool_free2 with functions
15496 - MINOR: memory: cut pool allocator in 3 layers
15497 - MEDIUM: memory: improve pool_refill_alloc() to pass a refill count
15498 - MINOR: stream-int: retrieve session pointer from stream-int
15499 - MINOR: buffer: reset a buffer in b_reset() and not channel_init()
15500 - MEDIUM: buffer: use b_alloc() to allocate and initialize a buffer
15501 - MINOR: buffer: move buffer initialization after channel initialization
15502 - MINOR: buffer: only use b_free to release buffers
15503 - MEDIUM: buffer: always assign a dummy empty buffer to channels
15504 - MEDIUM: buffer: add a new buf_wanted dummy buffer to report failed allocations
15505 - MEDIUM: channel: do not report full when buf_empty is present on a channel
15506 - MINOR: session: group buffer allocations together
15507 - MINOR: buffer: implement b_alloc_fast()
15508 - MEDIUM: buffer: implement b_alloc_margin()
15509 - MEDIUM: session: implement a basic atomic buffer allocator
15510 - MAJOR: session: implement a wait-queue for sessions who need a buffer
15511 - MAJOR: session: only allocate buffers when needed
15512 - MINOR: stats: report a "waiting" flags for sessions
15513 - MAJOR: session: only wake up as many sessions as available buffers permit
15514 - MINOR: config: implement global setting tune.buffers.reserve
15515 - MINOR: config: implement global setting tune.buffers.limit
15516 - MEDIUM: channel: implement a zero-copy buffer transfer
15517 - MEDIUM: stream-int: support splicing from applets
15518 - OPTIM: stream-int: try to send pending spliced data
15519 - CLEANUP: session: remove session_from_task()
15520 - DOC: add missing entry for log-format and clarify the text
15521 - MINOR: logs: add a new per-proxy "log-tag" directive
15522 - BUG/MEDIUM: http: fix header removal when previous header ends with pure LF
15523 - MINOR: config: extend the default max hostname length to 64 and beyond
15524 - BUG/MEDIUM: channel: fix possible integer overflow on reserved size computation
15525 - BUG/MINOR: channel: compare to_forward with buf->i, not buf->size
15526 - MINOR: channel: add channel_in_transit()
15527 - MEDIUM: channel: make buffer_reserved() use channel_in_transit()
15528 - MEDIUM: channel: make bi_avail() use channel_in_transit()
15529 - BUG/MEDIUM: channel: don't schedule data in transit for leaving until connected
15530 - CLEANUP: channel: rename channel_reserved -> channel_is_rewritable
15531 - MINOR: channel: rename channel_full() to !channel_may_recv()
15532 - MINOR: channel: rename buffer_reserved() to channel_reserved()
15533 - MINOR: channel: rename buffer_max_len() to channel_recv_limit()
15534 - MINOR: channel: rename bi_avail() to channel_recv_max()
15535 - MINOR: channel: rename bi_erase() to channel_truncate()
15536 - BUG/MAJOR: log: don't try to emit a log if no logger is set
15537 - MINOR: tools: add new round_2dig() function to round integers
15538 - MINOR: global: always export some SSL-specific metrics
15539 - MINOR: global: report information about the cost of SSL connections
15540 - MAJOR: init: automatically set maxconn and/or maxsslconn when possible
15541 - MINOR: http: add a new fetch "query" to extract the request's query string
15542 - MINOR: hash: add new function hash_crc32
15543 - MINOR: samples: provide a "crc32" converter
15544 - MEDIUM: backend: add the crc32 hash algorithm for load balancing
15545 - BUG/MINOR: args: add missing entry for ARGT_MAP in arg_type_names
15546 - BUG/MEDIUM: http: make http-request set-header compute the string before removal
15547 - MEDIUM: args: use #define to specify the number of bits used by arg types and counts
15548 - MEDIUM: args: increase arg type to 5 bits and limit arg count to 5
15549 - MINOR: args: add type-specific flags for each arg in a list
15550 - MINOR: args: implement a new arg type for regex : ARGT_REG
15551 - MEDIUM: regex: add support for passing regex flags to regex_exec_match()
15552 - MEDIUM: samples: add a regsub converter to perform regex-based transformations
15553 - BUG/MINOR: sample: fix case sensitivity for the regsub converter
15554 - MEDIUM: http: implement http-request set-{method,path,query,uri}
15555 - DOC: fix missing closing brackend on regsub
15556 - MEDIUM: samples: provide basic arithmetic and bitwise operators
15557 - MEDIUM: init: continue to enforce SYSTEM_MAXCONN with auto settings if set
15558 - BUG/MINOR: http: fix incorrect header value offset in replace-hdr/replace-value
15559 - BUG/MINOR: http: abort request processing on filter failure
15560 - MEDIUM: tcp: implement tcp-ut bind option to set TCP_USER_TIMEOUT
15561 - MINOR: ssl/server: add the "no-ssl-reuse" server option
15562 - BUG/MAJOR: peers: initialize s->buffer_wait when creating the session
15563 - MINOR: http: add a new function to iterate over each header line
15564 - MINOR: http: add the new sample fetches req.hdr_names and res.hdr_names
15565 - MEDIUM: task: always ensure that the run queue is consistent
15566 - BUILD: Makefile: add -Wdeclaration-after-statement
15567 - BUILD/CLEANUP: ssl: avoid a warning due to mixed code and declaration
15568 - BUILD/CLEANUP: config: silent 3 warnings about mixed declarations with code
15569 - MEDIUM: protocol: use a family array to index the protocol handlers
15570 - BUILD: lua: cleanup many mixed occurrences declarations & code
15571 - BUG/MEDIUM: task: fix recently introduced scheduler skew
15572 - BUG/MINOR: lua: report the correct function name in an error message
15573 - BUG/MAJOR: http: fix stats regression consecutive to HTTP_RULE_RES_YIELD
15574 - Revert "BUG/MEDIUM: lua: can't handle the response bytes"
15575 - MINOR: lua: convert IP addresses to type string
15576 - CLEANUP: lua: use the same function names in C and Lua
15577 - REORG/MAJOR: move session's req and resp channels back into the session
15578 - CLEANUP: remove now unused channel pool
15579 - REORG/MEDIUM: stream-int: introduce si_ic/si_oc to access channels
15580 - MEDIUM: stream-int: add a flag indicating which side the SI is on
15581 - MAJOR: stream-int: only rely on SI_FL_ISBACK to find the requested channel
15582 - MEDIUM: stream-interface: remove now unused pointers to channels
15583 - MEDIUM: stream-int: make si_sess() use the stream int's side
15584 - MEDIUM: stream-int: use si_task() to retrieve the task from the stream int
15585 - MEDIUM: stream-int: remove any reference to the owner
15586 - CLEANUP: stream-int: add si_ib/si_ob to dereference the buffers
15587 - CLEANUP: stream-int: add si_opposite() to find the other stream interface
15588 - REORG/MEDIUM: channel: only use chn_prod / chn_cons to find stream-interfaces
15589 - MEDIUM: channel: add a new flag "CF_ISRESP" for the response channel
15590 - MAJOR: channel: only rely on the new CF_ISRESP flag to find the SI
15591 - MEDIUM: channel: remove now unused ->prod and ->cons pointers
15592 - CLEANUP: session: simplify references to chn_{prod,cons}(&s->{req,res})
15593 - CLEANUP: session: use local variables to access channels / stream ints
15594 - CLEANUP: session: don't needlessly pass a pointer to the stream-int
15595 - CLEANUP: session: don't use si_{ic,oc} when we know the session.
15596 - CLEANUP: stream-int: limit usage of si_ic/si_oc
15597 - CLEANUP: lua: limit usage of si_ic/si_oc
15598 - MINOR: channel: add chn_sess() helper to retrieve session from channel
15599 - MEDIUM: session: simplify receive buffer allocator to only use the channel
15600 - MEDIUM: lua: use CF_ISRESP to detect the channel's side
15601 - CLEANUP: lua: remove the session pointer from hlua_channel
15602 - CLEANUP: lua: hlua_channel_new() doesn't need the pointer to the session anymore
15603 - MEDIUM: lua: remove struct hlua_channel
15604 - MEDIUM: lua: remove hlua_sample_fetch
15605
Willy Tarreau15480d72014-06-19 21:10:58 +0200156062014/06/19 : 1.6-dev0
15607 - exact copy of 1.5.0
15608
Willy Tarreau9229f122014-06-19 21:01:06 +0200156092014/06/19 : 1.5.0
15610 - MEDIUM: ssl: ignored file names ending as '.issuer' or '.ocsp'.
15611 - MEDIUM: ssl: basic OCSP stapling support.
15612 - MINOR: ssl/cli: Fix unapropriate comment in code on 'set ssl ocsp-response'
15613 - MEDIUM: ssl: add 300s supported time skew on OCSP response update.
15614 - MINOR: checks: mysql-check: Add support for v4.1+ authentication
15615 - MEDIUM: ssl: Add the option to use standardized DH parameters >= 1024 bits
15616 - MEDIUM: ssl: fix detection of ephemeral diffie-hellman key exchange by using the cipher description.
15617 - MEDIUM: http: add actions "replace-header" and "replace-values" in http-req/resp
15618 - MEDIUM: Break out check establishment into connect_chk()
15619 - MEDIUM: Add port_to_str helper
15620 - BUG/MEDIUM: fix ignored values for half-closed timeouts (client-fin and server-fin) in defaults section.
15621 - BUG/MEDIUM: Fix unhandled connections problem with systemd daemon mode and SO_REUSEPORT.
15622 - MINOR: regex: fix a little configuration memory leak.
15623 - MINOR: regex: Create JIT compatible function that return match strings
15624 - MEDIUM: regex: replace all standard regex function by own functions
15625 - MEDIUM: regex: Remove null terminated strings.
15626 - MINOR: regex: Use native PCRE API.
15627 - MINOR: missing regex.h include
15628 - DOC: Add Exim as Proxy Protocol implementer.
15629 - BUILD: don't use type "uint" which is not portable
15630 - BUILD: stats: workaround stupid and bogus -Werror=format-security behaviour
15631 - BUG/MEDIUM: http: clear CF_READ_NOEXP when preparing a new transaction
15632 - CLEANUP: http: don't clear CF_READ_NOEXP twice
15633 - DOC: fix proxy protocol v2 decoder example
15634 - DOC: fix remaining occurrences of "pattern extraction"
15635 - MINOR: log: allow the HTTP status code to be logged even in TCP frontends
15636 - MINOR: logs: don't limit HTTP header captures to HTTP frontends
15637 - MINOR: sample: improve sample_fetch_string() to report partial contents
15638 - MINOR: capture: extend the captures to support non-header keys
15639 - MINOR: tcp: prepare support for the "capture" action
15640 - MEDIUM: tcp: add a new tcp-request capture directive
15641 - MEDIUM: session: allow shorter retry delay if timeout connect is small
15642 - MEDIUM: session: don't apply the retry delay when redispatching
15643 - MEDIUM: session: redispatch earlier when possible
15644 - MINOR: config: warn when tcp-check rules are used without option tcp-check
15645 - BUG/MINOR: connection: make proxy protocol v1 support the UNKNOWN protocol
15646 - DOC: proxy protocol example parser was still wrong
15647 - DOC: minor updates to the proxy protocol doc
15648 - CLEANUP: connection: merge proxy proto v2 header and address block
15649 - MEDIUM: connection: add support for proxy protocol v2 in accept-proxy
15650 - MINOR: tools: add new functions to quote-encode strings
15651 - DOC: clarify the CSV format
15652 - MEDIUM: stats: report the last check and last agent's output on the CSV status
15653 - MINOR: freq_ctr: introduce a new averaging method
15654 - MEDIUM: session: maintain per-backend and per-server time statistics
15655 - MEDIUM: stats: report per-backend and per-server time stats in HTML and CSV outputs
15656 - BUG/MINOR: http: fix typos in previous patch
15657 - DOC: remove the ultra-obsolete TODO file
15658 - DOC: update roadmap
15659 - DOC: minor updates to the README
15660 - DOC: mention the maxconn limitations with the select poller
15661 - DOC: commit a few old design thoughts files
15662
Willy Tarreau2e858402014-05-28 17:50:53 +0200156632014/05/28 : 1.5-dev26
15664 - BUG/MEDIUM: polling: fix possible CPU hogging of worker processes after receiving SIGUSR1.
15665 - BUG/MINOR: stats: fix a typo on a closing tag for a server tracking another one
15666 - OPTIM: stats: avoid the calculation of a useless link on tracking servers in maintenance
15667 - MINOR: fix a few memory usage errors
15668 - CONTRIB: halog: Filter input lines by date and time through timestamp
15669 - MINOR: ssl: SSL_CTX_set_options() and SSL_CTX_set_mode() take a long, not an int
15670 - BUG/MEDIUM: regex: fix risk of buffer overrun in exp_replace()
15671 - MINOR: acl: set "str" as default match for strings
15672 - DOC: Add some precisions about acl default matching method
15673 - MEDIUM: acl: strenghten the option parser to report invalid options
15674 - BUG/MEDIUM: config: a stats-less config crashes in 1.5-dev25
15675 - BUG/MINOR: checks: tcp-check must not stop on '\0' for binary checks
15676 - MINOR: stats: improve alignment of color codes to save one line of header
15677 - MINOR: checks: simplify and improve reporting of state changes when using log-health-checks
15678 - MINOR: server: remove the SRV_DRAIN flag which can always be deduced
15679 - MINOR: server: use functions to detect state changes and to update them
15680 - MINOR: server: create srv_was_usable() from srv_is_usable() and use a pointer
15681 - BUG/MINOR: stats: do not report "100%" in the thottle column when server is draining
15682 - BUG/MAJOR: config: don't free valid regex memory
15683 - BUG/MEDIUM: session: don't clear CF_READ_NOEXP if analysers are not called
15684 - BUG/MINOR: stats: tracking servers may incorrectly report an inherited DRAIN status
15685 - MEDIUM: proxy: make timeout parser a bit stricter
15686 - REORG/MEDIUM: server: split server state and flags in two different variables
15687 - REORG/MEDIUM: server: move the maintenance bits out of the server state
15688 - MAJOR: server: use states instead of flags to store the server state
15689 - REORG: checks: put the functions in the appropriate files !
15690 - MEDIUM: server: properly support and propagate the maintenance status
15691 - MEDIUM: server: allow multi-level server tracking
15692 - CLEANUP: checks: rename the server_status_printf function
15693 - MEDIUM: checks: simplify server up/down/nolb transitions
15694 - MAJOR: checks: move health checks changes to set_server_check_status()
15695 - MINOR: server: make the status reporting function support a reason
15696 - MINOR: checks: simplify health check reporting functions
15697 - MINOR: server: implement srv_set_stopped()
15698 - MINOR: server: implement srv_set_running()
15699 - MINOR: server: implement srv_set_stopping()
15700 - MEDIUM: checks: simplify failure notification using srv_set_stopped()
15701 - MEDIUM: checks: simplify success notification using srv_set_running()
15702 - MEDIUM: checks: simplify stopping mode notification using srv_set_stopping()
15703 - MEDIUM: stats: report a server's own state instead of the tracked one's
15704 - MINOR: server: make use of srv_is_usable() instead of checking eweight
15705 - MAJOR: checks: add support for a new "drain" administrative mode
15706 - MINOR: stats: use the admin flags for soft enable/disable/stop/start on the web page
15707 - MEDIUM: stats: introduce new actions to simplify admin status management
15708 - MINOR: cli: introduce a new "set server" command
15709 - MINOR: stats: report a distinct output for DOWN caused by agent
15710 - MINOR: checks: support specific check reporting for the agent
15711 - MINOR: checks: support a neutral check result
15712 - BUG/MINOR: cli: "agent" was missing from the "enable"/"disable" help message
15713 - MEDIUM: cli: add support for enabling/disabling health checks.
15714 - MEDIUM: stats: report down caused by agent prior to reporting up
15715 - MAJOR: agent: rework the response processing and support additional actions
15716 - MINOR: stats: improve the stats web page to support more actions
15717 - CONTRIB: halog: avoid calling time/localtime/mktime for each line
15718 - DOC: document the workarouds for Google Chrome's bogus pre-connect
15719 - MINOR: stats: report SSL key computations per second
15720 - MINOR: stats: add counters for SSL cache lookups and misses
15721
Willy Tarreaua3393952014-05-10 15:16:43 +0200157222014/05/10 : 1.5-dev25
15723 - MEDIUM: connection: Implement and extented PROXY Protocol V2
15724 - MINOR: ssl: clean unused ACLs declarations
15725 - MINOR: ssl: adds fetchs and ACLs for ssl back connection.
15726 - MINOR: ssl: merge client's and frontend's certificate functions.
15727 - MINOR: ssl: adds ssl_f_sha1 fetch to return frontend's certificate fingerprint
15728 - MINOR: ssl: adds sample converter base64 for binary type.
15729 - MINOR: ssl: convert to binary ssl_fc_unique_id and ssl_bc_unique_id.
15730 - BUG/MAJOR: ssl: Fallback to private session cache if current lock mode is not supported.
15731 - MAJOR: ssl: Change default locks on ssl session cache.
15732 - BUG/MINOR: chunk: Fix function chunk_strcmp and chunk_strcasecmp match a substring.
15733 - MINOR: ssl: add global statement tune.ssl.force-private-cache.
15734 - MINOR: ssl: remove fallback to SSL session private cache if lock init fails.
15735 - BUG/MEDIUM: patterns: last fix was still not enough
15736 - MINOR: http: export the smp_fetch_cookie function
15737 - MINOR: http: generic pointer to rule argument
15738 - BUG/MEDIUM: pattern: a typo breaks automatic acl/map numbering
15739 - BUG/MAJOR: patterns: -i and -n are ignored for inlined patterns
15740 - BUG/MINOR: proxy: unsafe initialization of HTTP transaction when switching from TCP frontend
15741 - BUG/MINOR: http: log 407 in case of proxy auth
15742 - MINOR: http: rely on the message body parser to send 100-continue
15743 - MEDIUM: http: move reqadd after execution of http_request redirect
15744 - MEDIUM: http: jump to dedicated labels after http-request processing
15745 - BUG/MINOR: http: block rules forgot to increment the denied_req counter
15746 - BUG/MINOR: http: block rules forgot to increment the session's request counter
15747 - MEDIUM: http: move Connection header processing earlier
15748 - MEDIUM: http: remove even more of the spaghetti in the request path
15749 - MINOR: http: silently support the "block" action for http-request
15750 - CLEANUP: proxy: rename "block_cond" to "block_rules"
15751 - MEDIUM: http: emulate "block" rules using "http-request" rules
15752 - MINOR: http: remove the now unused loop over "block" rules
15753 - MEDIUM: http: factorize the "auth" action of http-request and stats
15754 - MEDIUM: http: make http-request rules processing return a verdict instead of a rule
15755 - MINOR: config: add minimum support for emitting warnings only once
15756 - MEDIUM: config: inform the user about the deprecatedness of "block" rules
15757 - MEDIUM: config: inform the user that "reqsetbe" is deprecated
15758 - MEDIUM: config: inform the user only once that "redispatch" is deprecated
15759 - MEDIUM: config: warn that '{cli,con,srv}timeout' are deprecated
15760 - BUG/MINOR: auth: fix wrong return type in pat_match_auth()
15761 - BUILD: config: remove a warning with clang
15762 - BUG/MAJOR: http: connection setup may stall on balance url_param
15763 - BUG/MEDIUM: http/session: disable client-side expiration only after body
15764 - BUG/MEDIUM: http: correctly report request body timeouts
15765 - BUG/MEDIUM: http: disable server-side expiration until client has sent the body
15766 - MEDIUM: listener: make the accept function more robust against pauses
15767 - BUILD: syscalls: remove improper inline statement in front of syscalls
15768 - BUILD: ssl: SSL_CTX_set_msg_callback() needs openssl >= 0.9.7
15769 - BUG/MAJOR: session: recover the correct connection pointer in half-initialized sessions
15770 - DOC: add some explanation on the shared cache build options in the readme.
15771 - MEDIUM: proxy: only adjust the backend's bind-process when already set
15772 - MEDIUM: config: limit nbproc to the machine's word size
15773 - MEDIUM: config: check the bind-process settings according to nbproc
15774 - MEDIUM: listener: parse the new "process" bind keyword
15775 - MEDIUM: listener: inherit the process mask from the proxy
15776 - MAJOR: listener: only start listeners bound to the same processes
15777 - MINOR: config: only report a warning when stats sockets are bound to more than 1 process
15778 - CLEANUP: config: set the maxaccept value for peers listeners earlier
15779 - BUG/MINOR: backend: only match IPv4 addresses with RDP cookies
15780 - BUG/MINOR: checks: correctly configure the address family and protocol
15781 - MINOR: tools: split is_addr() and is_inet_addr()
15782 - MINOR: protocols: use is_inet_addr() when only INET addresses are desired
15783 - MEDIUM: unix: add preliminary support for connecting to servers over UNIX sockets
15784 - MEDIUM: checks: only complain about the missing port when the check uses TCP
15785 - MEDIUM: unix: implement support for Linux abstract namespace sockets
15786 - DOC: map_beg was missing from the table of map_* converters
15787 - DOC: ebtree: indicate that prefix insertion/lookup may be used with strings
15788 - MEDIUM: pattern: use ebtree's longest match to index/lookup string beginning
15789 - BUILD: remove the obsolete BSD and OSX makefiles
15790 - MEDIUM: unix: avoid a double connect probe when no data are sent
15791 - DOC: stop referencing the slow git repository in the README
15792 - BUILD: only build the systemd wrapper on Linux 2.6 and above
15793 - DOC: update roadmap with completed tasks
15794 - MEDIUM: session: implement half-closed timeouts (client-fin and server-fin)
15795
Willy Tarreau8860dcd2014-04-26 00:08:14 +0200157962014/04/26 : 1.5-dev24
15797 - MINOR: pattern: find element in a reference
15798 - MEDIUM: http: ACL and MAP updates through http-(request|response) rules
15799 - MEDIUM: ssl: explicitly log failed handshakes after a heartbeat
15800 - DOC: Full section dedicated to the converters
15801 - MEDIUM: http: register http-request and http-response keywords
15802 - BUG/MINOR: compression: correctly report incoming byte count
15803 - BUG/MINOR: http: don't report server aborts as client aborts
15804 - BUG/MEDIUM: channel: bi_putblk() must not wrap before the end of buffer
15805 - CLEANUP: buffers: remove unused function buffer_contig_space_with_res()
15806 - MEDIUM: stats: reimplement HTTP keep-alive on the stats page
15807 - BUG/MAJOR: http: fix timeouts during data forwarding
15808 - BUG/MEDIUM: http: 100-continue responses must process the next part immediately
15809 - MEDIUM: http: move skipping of 100-continue earlier
15810 - BUILD: stats: let gcc know that last_fwd cannot be used uninitialized...
15811 - CLEANUP: general: get rid of all old occurrences of "session *t"
15812 - CLEANUP: http: remove the useless "if (1)" inherited from version 1.4
15813 - BUG/MEDIUM: stats: mismatch between behaviour and doc about front/back
15814 - MEDIUM: http: enable analysers to have keep-alive on stats
15815 - REORG: http: move HTTP Connection response header parsing earlier
15816 - MINOR: stats: always emit HTTP/1.1 in responses
15817 - MINOR: http: add capture.req.ver and capture.res.ver
15818 - MINOR: checks: add a new global max-spread-checks directive
15819 - BUG/MAJOR: http: fix the 'next' pointer when performing a redirect
15820 - MINOR: http: implement the max-keep-alive-queue setting
15821 - DOC: fix alphabetic order of tcp-check
15822 - MINOR: connection: add a new error code for SSL with heartbeat
15823 - MEDIUM: ssl: implement a workaround for the OpenSSL heartbleed attack
15824 - BUG/MEDIUM: Revert "MEDIUM: ssl: Add standardized DH parameters >= 1024 bits"
15825 - BUILD: http: remove a warning on strndup
15826 - BUILD: ssl: avoid a warning about conn not used with OpenSSL < 1.0.1
15827 - BUG/MINOR: ssl: really block OpenSSL's response to heartbleed attack
15828 - MINOR: ssl: finally catch the heartbeats missing the padding
15829
Willy Tarreau8317b282014-04-23 01:49:41 +0200158302014/04/23 : 1.5-dev23
15831 - BUG/MINOR: reject malformed HTTP/0.9 requests
15832 - MINOR: systemd wrapper: re-execute on SIGUSR2
15833 - MINOR: systemd wrapper: improve logging
15834 - MINOR: systemd wrapper: propagate exit status
15835 - BUG/MINOR: tcpcheck connect wrong behavior
15836 - MEDIUM: proxy: support use_backend with dynamic names
15837 - MINOR: stats: Enhancement to stats page to provide information of last session time.
15838 - BUG/MEDIUM: peers: fix key consistency for integer stick tables
15839 - DOC: fix a typo on http-server-close and encapsulate options with double-quotes
15840 - DOC: fix fetching samples syntax
15841 - MINOR: ssl: add ssl_fc_unique_id to fetch TLS Unique ID
15842 - MEDIUM: ssl: Use ALPN support as it will be available in OpenSSL 1.0.2
15843 - DOC: fix typo
15844 - CLEANUP: code style: use tabs to indent codes instead of spaces
15845 - DOC: fix a few config typos.
15846 - BUG/MINOR: raw_sock: also consider ENOTCONN in addition to EAGAIN for recv()
15847 - DOC: lowercase format string in unique-id
15848 - MINOR: set IP_FREEBIND on IPv6 sockets in transparent mode
15849 - BUG/MINOR: acl: req_ssl_sni fails with SSLv3 record version
15850 - BUG/MINOR: build: add missing objects in osx and bsd Makefiles
15851 - BUG/MINOR: build: handle whitespaces in wc -l output
15852 - BUG/MINOR: Fix name lookup ordering when compiled with USE_GETADDRINFO
15853 - MEDIUM: ssl: Add standardized DH parameters >= 1024 bits
15854 - BUG/MEDIUM: map: The map parser includes blank lines.
15855 - BUG/MINOR: log: The log of quotted capture header has been terminated by 2 quotes.
15856 - MINOR: standard: add function "encode_chunk"
15857 - BUG/MINOR: http: fix encoding of samples used in http headers
15858 - MINOR: sample: add hex converter
15859 - MEDIUM: sample: change the behavior of the bin2str cast
15860 - MAJOR: auth: Change the internal authentication system.
15861 - MEDIUM: acl/pattern: standardisation "of pat_parse_int()" and "pat_parse_dotted_ver()"
15862 - MEDIUM: pattern: The pattern parser no more uses <opaque> and just takes one string.
15863 - MEDIUM: pattern: Change the prototype of the function pattern_register().
15864 - CONTRIB: ip6range: add a network IPv6 range to mask converter
15865 - MINOR: pattern: separe list element from the data part.
15866 - MEDIUM: pattern: add indexation function.
15867 - MEDIUM: pattern: The parse functions just return "struct pattern" without memory allocation
15868 - MINOR: pattern: Rename "pat_idx_elt" to "pattern_tree"
15869 - MINOR: sample: dont call the sample cast function "c_none"
15870 - MINOR: standard: Add function for converting cidr to network mask.
15871 - MEDIUM: sample: Remove types SMP_T_CSTR and SMP_T_CBIN, replace it by SMP_F_CONST flags
15872 - MEDIUM: sample/http_proto: Add new type called method
15873 - MINOR: dumpstats: Group map inline help
15874 - MEDIUM: pattern: The function pattern_exec_match() returns "struct pattern" if the patten match.
15875 - MINOR: dumpstats: change map inline sentences
15876 - MINOR: dumpstats: change the "get map" display management
15877 - MINOR: map/dumpstats: The cli cmd "get map ..." display the "int" format.
15878 - MEDIUM: pattern: The match function browse itself the list or the tree.
15879 - MEDIUM: pattern: Index IPv6 addresses in a tree.
15880 - MEDIUM: pattern: add delete functions
15881 - MEDIUM: pattern: add prune function
15882 - MEDIUM: pattern: add sample lookup function.
15883 - MEDIUM: pattern/dumpstats: The function pattern_lookup() is no longer used
15884 - MINOR: map/pattern: The sample parser is stored in the pattern
15885 - MAJOR: pattern/map: Extends the map edition system in the patterns
15886 - MEDIUM: pattern: merge same pattern
15887 - MEDIUM: pattern: The expected type is stored in the pattern head, and conversion is executed once.
15888 - MINOR: pattern: Each pattern is identified by unique id.
15889 - MINOR: pattern/acl: Each pattern of each acl can be load with specified id
15890 - MINOR: pattern: The function "pattern_register()" is no longer used.
15891 - MINOR: pattern: Merge function pattern_add() with pat_ref_push().
15892 - MINOR: pattern: store configuration reference for each acl or map pattern.
15893 - MINOR: pattern: Each pattern expression element store the reference struct.
15894 - MINOR: dumpstats: display the reference for th key/pattern and value.
15895 - MEDIUM: pattern: delete() function uses the pat_ref_elt to find the element to be removed
15896 - MEDIUM: pattern_find_smp: functions find_smp uses the pat_ref_elt to find the element to be removed
15897 - MEDIUM: dumpstats/pattern: display and use each pointer of each pattern dumped
15898 - MINOR: pattern/map/acl: Centralization of the file parsers
15899 - MINOR: pattern: Check if the file reference is not used with acl and map
15900 - MINOR: acl/pattern: Acl "-M" option force to load file as map file with two columns
15901 - MEDIUM: dumpstats: Display error message during add of values.
15902 - MINOR: pattern: The function pat_ref_set() have now atomic behavior
15903 - MINOR: regex: The pointer regstr in the struc regex is no longer used.
15904 - MINOR: cli: Block the usage of the command "acl add" in many cases.
15905 - MINOR: doc: Update the documentation about the map and acl
15906 - MINOR: pattern: index duplicates
15907 - MINOR: configuration: File and line propagation
15908 - MINOR: dumpstat/conf: display all the configuration lines that using pattern reference
15909 - MINOR: standard: Disable ip resolution during the runtime
15910 - MINOR: pattern: Remove the flag "PAT_F_FROM_FILE".
15911 - MINOR: pattern: forbid dns resolutions
15912 - DOC: document "get map" / "get acl" on the CLI
15913 - MEDIUM: acl: Change the acl register struct
15914 - BUG/MEDIUM: acl: boolean only matches were broken by recent changes
15915 - DOC: pattern: pattern organisation schematics
15916 - MINOR: pattern/cli: Update used terms in documentation and cli
15917 - MINOR: cli: remove information about acl or map owner.
15918 - MINOR: session: don't always assume there's a listener
15919 - MINOR: pattern: Add function to prune and reload pattern list.
15920 - MINOR: standard: Add ipv6 support in the function url2sa().
15921 - MEDIUM: config: Dynamic sections.
15922 - BUG/MEDIUM: stick-table: fix IPv4-to-IPv6 conversion in src_* fetches
15923 - MINOR: http: Add the "language" converter to for use with accept-language
15924 - BUG/MINOR: log: Don't dump empty unique-id
15925 - BUG/MAJOR: session: fix a possible crash with src_tracked
15926 - DOC: Update "language" documentation
15927 - MINOR: http: add the function "del-header" to the directives http-request and http-response
15928 - DOC: add some information on capture.(req|res).hdr
15929 - MINOR: http: capture.req.method and capture.req.uri
15930 - MINOR: http: optimize capture.req.method and capture.req.uri
15931 - MINOR: session: clean up the connection free code
15932 - BUG/MEDIUM: checks: immediately report a connection success
15933 - MEDIUM: connection: don't use real send() flags in snd_buf()
15934 - OPTIM: ssl: implement dynamic record size adjustment
15935 - MINOR: stats: report exact last session time in backend too
15936 - BUG/MEDIUM: stats: the "lastsess" field must appear last in the CSV.
15937 - BUG/MAJOR: check: fix memory leak in "tcp-check connect" over SSL
15938 - BUG/MINOR: channel: initialize xfer_small/xfer_large on new buffers
15939 - MINOR: channel: add the date of last read in the channel
15940 - MEDIUM: stream-int: automatically disable CF_STREAMER flags after idle
15941 - MINOR: ssl: add DEFAULT_SSL_MAX_RECORD to set the record size at build time
15942 - MINOR: config: make the stream interface idle timer user-configurable
15943 - MINOR: config: add global directives to set default SSL ciphers
15944 - MINOR: sample: add a rand() sample fetch to return a sample.
15945 - BUG/MEDIUM: config: immediately abort if peers section has no name
15946 - BUG/MINOR: ssl: fix syntax in config error message
15947 - BUG/MEDIUM: ssl: always send a full buffer after EAGAIN
15948 - BUG/MINOR: config: server on-marked-* statement is ignored in default-server
15949 - BUG/MEDIUM: backend: prefer-last-server breaks redispatch
15950 - BUG/MEDIUM: http: continue to emit 503 on keep-alive to different server
15951 - MEDIUM: acl: fix pattern type for payload / payload_lv
15952 - BUG/MINOR: config: fix a crash on startup when a disabled backend references a peer
15953 - BUG/MEDIUM: compression: fix the output type of the compressor name
15954 - BUG/MEDIUM: http: don't start to forward request data before the connect
15955 - MINOR: http: release compression context only in http_end_txn()
15956 - MINOR: protect ebimtree/ebistree against multiple inclusions
15957 - MEDIUM: proxy: create a tree to store proxies by name
15958 - MEDIUM: proxy: make findproxy() use trees to look up proxies
15959 - MEDIUM: proxy: make get_backend_server() use findproxy() to lookup proxies
15960 - MEDIUM: stick-table: lookup table names using trees.
15961 - MEDIUM: config: faster lookup for duplicated proxy name
15962 - CLEANUP: acl: remove obsolete test in parse_acl_expr()
15963 - MINOR: sample: move smp_to_type to sample.c
15964 - MEDIUM: compression: consider the "q=" attribute in Accept-Encoding
15965 - REORG: cfgparse: move server keyword parsing to server.c
15966 - BUILD: adjust makefile for AIX 5.1
15967 - BUG/MEDIUM: pattern: fix wrong definition of the pat_prune_fcts array
15968 - CLEANUP: pattern: move array definitions to proto/ and not types/
15969 - BUG/MAJOR: counters: check for null-deref when looking up an alternate table
15970 - BUILD: ssl: previous patch failed
15971 - BUILD/MEDIUM: standard: get rid of the last strcpy()
15972 - BUILD/MEDIUM: standard: get rid of sprintf()
15973 - BUILD/MEDIUM: cfgparse: get rid of sprintf()
15974 - BUILD/MEDIUM: checks: get rid of sprintf()
15975 - BUILD/MEDIUM: http: remove calls to sprintf()
15976 - BUG/MEDIUM: systemd-wrapper: fix locating of haproxy binary
15977 - BUILD/MINOR: ssl: remove one call to sprintf()
15978 - MEDIUM: http: don't reject anymore message bodies not containing the url param
15979 - MEDIUM: http: wait for the first chunk or message body length in http_process_body
15980 - CLEANUP: http: rename http_process_request_body()
15981 - CLEANUP: http: prepare dedicated processing for chunked encoded message bodies
15982 - MINOR: http: make msg->eol carry the last CRLF length
15983 - MAJOR: http: do not use msg->sol while processing messages or forwarding data
15984 - MEDIUM: http: http_parse_chunk_crlf() must not advance the buffer pointer
15985 - MAJOR: http: don't update msg->sov anymore while processing the body
15986 - MINOR: http: add a small helper to compute the amount of body bytes present
15987 - MEDIUM: http: add a small helper to compute how far to rewind to find headers
15988 - MINOR: http: add a small helper to compute how far to rewind to find URI
15989 - MEDIUM: http: small helpers to compute how far to rewind to find BODY and DATA
15990 - MAJOR: http: reset msg->sov after headers are forwarded
15991 - MEDIUM: http: forward headers again while waiting for connection to complete
15992 - BUG/MINOR: http: deinitialize compression after a parsing error
15993 - BUG/MINOR: http: deinitialize compression after a compression error
15994 - MEDIUM: http: headers must be forwarded even if data was already inspected
15995 - MAJOR: http: re-enable compression on chunked encoding
15996 - MAJOR: http/compression: fix chunked-encoded response processing
15997 - MEDIUM: http: cleanup: centralize a little bit HTTP compression end
15998 - MEDIUM: http: start to centralize the forwarding code
15999 - MINOR: http: further cleanups of response forwarding function
16000 - MEDIUM: http: only allocate the temporary compression buffer when needed
16001 - MAJOR: http: centralize data forwarding in the request path
16002 - CLEANUP: http: document the response forwarding states
16003 - CLEANUP: http: remove all calls to http_silent_debug()
16004 - DOC: internal: add some reminders about HTTP parsing and pointer states
16005 - BUG/MAJOR: http: fix bug in parse_qvalue() when selecting compression algo
16006 - BUG/MINOR: stats: last session was not always set
16007 - DOC: add pointer to the Cyril's HTML doc in the README
16008 - MEDIUM: config: relax use_backend check to make the condition optional
16009 - MEDIUM: config: report misplaced http-request rules
16010 - MEDIUM: config: report misplaced use-server rules
16011 - DOC: update roadmap with what was done.
16012
Willy Tarreau1a34d572014-02-03 00:41:29 +0100160132014/02/03 : 1.5-dev22
16014 - MEDIUM: tcp-check new feature: connect
16015 - MEDIUM: ssl: Set verify 'required' as global default for servers side.
16016 - MINOR: ssl: handshake optim for long certificate chains.
16017 - BUG/MINOR: pattern: pattern comparison executed twice
16018 - BUG/MEDIUM: map: segmentation fault with the stats's socket command "set map ..."
16019 - BUG/MEDIUM: pattern: Segfault in binary parser
16020 - MINOR: pattern: move functions for grouping pat_match_* and pat_parse_* and add documentation.
16021 - MINOR: standard: The parse_binary() returns the length consumed and his documentation is updated
16022 - BUG/MINOR: payload: the patterns of the acl "req.ssl_ver" are no parsed with the good function.
16023 - BUG/MEDIUM: pattern: "pat_parse_dotted_ver()" set bad expect_type.
16024 - BUG/MINOR: sample: The c_str2int converter does not fail if the entry is not an integer
16025 - BUG/MEDIUM: http/auth: Sometimes the authentication credentials can be mix between two requests
16026 - MINOR: doc: Bad cli function name.
16027 - MINOR: http: smp_fetch_capture_header_* fetch captured headers
16028 - BUILD: last release inadvertently prepended a "+" in front of the date
16029 - BUG/MEDIUM: stream-int: fix the keep-alive idle connection handler
16030 - BUG/MEDIUM: backend: do not re-initialize the connection's context upon reuse
16031 - BUG: Revert "OPTIM/MEDIUM: epoll: fuse active events into polled ones during polling changes"
16032 - BUG/MINOR: checks: successful check completion must not re-enable MAINT servers
16033 - MINOR: http: try to stick to same server after status 401/407
16034 - BUG/MINOR: http: always disable compression on HTTP/1.0
16035 - OPTIM: poll: restore polling after a poll/stop/want sequence
16036 - OPTIM: http: don't stop polling for read on the client side after a request
16037 - BUG/MEDIUM: checks: unchecked servers could not be enabled anymore
16038 - BUG/MEDIUM: stats: the web interface must check the tracked servers before enabling
16039 - BUG/MINOR: channel: CHN_INFINITE_FORWARD must be unsigned
16040 - BUG/MINOR: stream-int: do not clear the owner upon unregister
16041 - MEDIUM: stats: add support for HTTP keep-alive on the stats page
16042 - BUG/MEDIUM: stats: fix HTTP/1.0 breakage introduced in previous patch
16043 - Revert "MEDIUM: stats: add support for HTTP keep-alive on the stats page"
16044 - MAJOR: channel: add a new flag CF_WAKE_WRITE to notify the task of writes
16045 - OPTIM: session: set the READ_DONTWAIT flag when connecting
16046 - BUG/MINOR: http: don't clear the SI_FL_DONT_WAKE flag between requests
16047 - MINOR: session: factor out the connect time measurement
16048 - MEDIUM: session: prepare to support earlier transitions to the established state
16049 - MEDIUM: stream-int: make si_connect() return an established state when possible
16050 - MINOR: checks: use an inline function for health_adjust()
16051 - OPTIM: session: put unlikely() around the freewheeling code
16052 - MEDIUM: config: report a warning when multiple servers have the same name
16053 - BUG: Revert "OPTIM: poll: restore polling after a poll/stop/want sequence"
16054 - BUILD/MINOR: listener: remove a glibc warning on accept4()
16055 - BUG/MAJOR: connection: fix mismatch between rcv_buf's API and usage
16056 - BUILD: listener: fix recent accept4() again
16057 - BUG/MAJOR: ssl: fix breakage caused by recent fix abf08d9
16058 - BUG/MEDIUM: polling: ensure we update FD status when there's no more activity
16059 - MEDIUM: listener: fix polling management in the accept loop
16060 - MINOR: protocol: improve the proto->drain() API
16061 - MINOR: connection: add a new conn_drain() function
16062 - MEDIUM: tcp: report in tcp_drain() that lingering is already disabled on close
16063 - MEDIUM: connection: update callers of ctrl->drain() to use conn_drain()
16064 - MINOR: connection: add more error codes to report connection errors
16065 - MEDIUM: tcp: report connection error at the connection level
16066 - MEDIUM: checks: make use of chk_report_conn_err() for connection errors
16067 - BUG/MEDIUM: unique_id: HTTP request counter is not stable
16068 - DOC: fix misleading information about SIGQUIT
16069 - BUG/MAJOR: fix freezes during compression
16070 - BUG/MEDIUM: stream-interface: don't wake the task up before end of transfer
16071 - BUILD: fix VERDATE exclusion regex
16072 - CLEANUP: polling: rename "spec_e" to "state"
16073 - DOC: add a diagram showing polling state transitions
16074 - REORG: polling: rename "spec_e" to "state" and "spec_p" to "cache"
16075 - REORG: polling: rename "fd_spec" to "fd_cache"
16076 - REORG: polling: rename the cache allocation functions
16077 - REORG: polling: rename "fd_process_spec_events()" to "fd_process_cached_events()"
16078 - MAJOR: polling: rework the whole polling system
16079 - MAJOR: connection: remove the CO_FL_WAIT_{RD,WR} flags
16080 - MEDIUM: connection: remove conn_{data,sock}_poll_{recv,send}
16081 - MEDIUM: connection: add check for readiness in I/O handlers
16082 - MEDIUM: stream-interface: the polling flags must always be updated in chk_snd_conn
16083 - MINOR: stream-interface: no need to call fd_stop_both() on error
16084 - MEDIUM: connection: no need to recheck FD state
16085 - CLEANUP: connection: use conn_ctrl_ready() instead of checking the flag
16086 - CLEANUP: connection: use conn_xprt_ready() instead of checking the flag
16087 - CLEANUP: connection: fix comments in connection.h to reflect new behaviour.
16088 - OPTIM: raw-sock: don't speculate after a short read if polling is enabled
16089 - MEDIUM: polling: centralize polled events processing
16090 - MINOR: polling: create function fd_compute_new_polled_status()
16091 - MINOR: cli: add more information to the "show info" output
16092 - MEDIUM: listener: add support for limiting the session rate in addition to the connection rate
16093 - MEDIUM: listener: apply a limit on the session rate submitted to SSL
16094 - REORG: stats: move the stats socket states to dumpstats.c
16095 - MINOR: cli: add the new "show pools" command
16096 - BUG/MEDIUM: counters: flush content counters after each request
16097 - BUG/MEDIUM: counters: fix stick-table entry leak when using track-sc2 in connection
16098 - MINOR: tools: add very basic support for composite pointers
16099 - MEDIUM: counters: stop relying on session flags at all
16100 - BUG/MINOR: cli: fix missing break in command line parser
16101 - BUG/MINOR: config: correctly report when log-format headers require HTTP mode
16102 - MAJOR: http: update connection mode configuration
16103 - MEDIUM: http: make keep-alive + httpclose be passive mode
16104 - MAJOR: http: switch to keep-alive mode by default
16105 - BUG/MEDIUM: http: fix regression caused by recent switch to keep-alive by default
16106 - BUG/MEDIUM: listener: improve detection of non-working accept4()
16107 - BUILD: listener: add fcntl.h and unistd.h
16108 - BUG/MINOR: raw_sock: correctly set the MSG_MORE flag
16109
Willy Tarreau6b07bf72013-12-17 00:45:49 +0100161102013/12/17 : 1.5-dev21
16111 - MINOR: stats: don't use a monospace font to report numbers
16112 - MINOR: session: remove debugging code
16113 - BUG/MAJOR: patterns: fix double free caused by loading strings from files
16114 - MEDIUM: http: make option http_proxy automatically rewrite the URL
16115 - BUG/MEDIUM: http: cook_cnt() forgets to set its output type
16116 - BUG/MINOR: stats: correctly report throttle rate of low weight servers
16117 - BUG/MEDIUM: checks: servers must not start in slowstart mode
16118 - BUG/MINOR: acl: parser must also stop at comma on ACL-only keywords
16119 - MEDIUM: stream-int: implement a very simplistic idle connection manager
16120 - DOC: update the ROADMAP file
16121
Willy Tarreau11f64d62013-12-16 02:32:37 +0100161222013/12/16 : 1.5-dev20
16123 - DOC: add missing options to the manpage
16124 - DOC: add manpage references to all system calls
16125 - DOC: update manpage reference to haproxy-en.txt
16126 - DOC: remove -s and -l options from the manpage
16127 - DOC: missing information for the "description" keyword
16128 - DOC: missing http-send-name-header keyword in keyword table
16129 - MINOR: tools: function my_memmem() to lookup binary contents
16130 - MEDIUM: checks: add send/expect tcp based check
16131 - MEDIUM: backend: Enhance hash-type directive with an algorithm options
16132 - MEDIUM: backend: Implement avalanche as a modifier of the hashing functions.
16133 - DOC: Documentation for hashing function, with test results.
16134 - BUG/MEDIUM: ssl: potential memory leak using verifyhost
16135 - BUILD: ssl: compilation issue with openssl v0.9.6.
16136 - BUG/MINOR: ssl: potential memory leaks using ssl_c_key_alg or ssl_c_sig_alg.
16137 - MINOR: ssl: optimization of verifyhost on wildcard certificates.
16138 - BUG/MINOR: ssl: verifyhost does not match empty strings on wildcard.
16139 - MINOR: ssl: Add statement 'verifyhost' to "server" statements
16140 - CLEANUP: session: remove event_accept() which was not used anymore
16141 - BUG/MINOR: deinit: free fdinfo while doing cleanup
16142 - DOC: minor typo fix in documentation
16143 - BUG/MEDIUM: server: set the macro for server's max weight SRV_UWGHT_MAX to SRV_UWGHT_RANGE
16144 - BUG/MINOR: use the same check condition for server as other algorithms
16145 - DOC: fix typo in comments
16146 - BUG/MINOR: deinit: free server map which is allocated in init_server_map()
16147 - CLEANUP: stream_interface: cleanup loop information in si_conn_send_loop()
16148 - MINOR: buffer: align the last output line of buffer_dump()
16149 - MINOR: buffer: align the last output line if there are less than 8 characters left
16150 - DOC: stick-table: modify the description
16151 - OPTIM: stream_interface: return directly if the connection flag CO_FL_ERROR has been set
16152 - CLEANUP: code style: use tabs to indent codes
16153 - DOC: checkcache: block responses with cacheable cookies
16154 - BUG/MINOR: check_config_validity: check the returned value of stktable_init()
16155 - MEDIUM: haproxy-systemd-wrapper: Use haproxy in same directory
16156 - MEDIUM: systemd-wrapper: Kill child processes when interrupted
16157 - LOW: systemd-wrapper: Write debug information to stdout
16158 - BUG/MINOR: http: fix "set-tos" not working in certain configurations
16159 - MEDIUM: http: add IPv6 support for "set-tos"
16160 - DOC: ssl: update build instructions to use new SSL_* variables
16161 - BUILD/MINOR: systemd: fix compiler warning about unused result
16162 - url32+src - like base32+src but whole url including parameters
16163 - BUG/MINOR: fix forcing fastinter in "on-error"
16164 - CLEANUP: Make parameters of srv_downtime and srv_getinter const
16165 - CLEANUP: Remove unused 'last_slowstart_change' field from struct peer
16166 - MEDIUM: Split up struct server's check element
16167 - MEDIUM: Move result element to struct check
16168 - MEDIUM: Paramatise functions over the check of a server
16169 - MEDIUM: cfgparse: Factor out check initialisation
16170 - MEDIUM: Add state to struct check
16171 - MEDIUM: Move health element to struct check
16172 - MEDIUM: Add helper for task creation for checks
16173 - MEDIUM: Add helper function for failed checks
16174 - MEDIUM: Log agent fail, stopped or down as info
16175 - MEDIUM: Remove option lb-agent-chk
16176 - MEDIUM: checks: Add supplementary agent checks
16177 - MEDIUM: Do not mark a server as down if the agent is unavailable
16178 - MEDIUM: Set rise and fall of agent checks to 1
16179 - MEDIUM: Add enable and disable agent unix socket commands
16180 - MEDIUM: Add DRAIN state and report it on the stats page
16181 - BUILD/MINOR: missing header file
16182 - CLEANUP: regex: Create regex_comp function that compiles regex using compilation options
16183 - CLEANUP: The function "regex_exec" needs the string length but in many case they expect null terminated char.
16184 - MINOR: http: some exported functions were not in the header file
16185 - MINOR: http: change url_decode to return the size of the decoded string.
16186 - BUILD/MINOR: missing header file
16187 - BUG/MEDIUM: sample: The function v4tov6 cannot support input and output overlap
16188 - BUG/MINOR: arg: fix error reporting for add-header/set-header sample fetch arguments
16189 - MINOR: sample: export the generic sample conversion parser
16190 - MINOR: sample: export sample_casts
16191 - MEDIUM: acl: use the fetch syntax 'fetch(args),conv(),conv()' into the ACL keyword
16192 - MINOR: stick-table: use smp_expr_output_type() to retrieve the output type of a "struct sample_expr"
16193 - MINOR: sample: provide the original sample_conv descriptor struct to the argument checker function.
16194 - MINOR: tools: Add a function to convert buffer to an ipv6 address
16195 - MINOR: acl: export acl arrays
16196 - MINOR: acl: Extract the pattern parsing and indexation from the "acl_read_patterns_from_file()" function
16197 - MINOR: acl: Extract the pattern matching function
16198 - MINOR: sample: Define new struct sample_storage
16199 - MEDIUM: acl: associate "struct sample_storage" to each "struct acl_pattern"
16200 - REORG: acl/pattern: extract pattern matching from the acl file and create pattern.c
16201 - MEDIUM: pattern: create pattern expression
16202 - MEDIUM: pattern: rename "acl" prefix to "pat"
16203 - MEDIUM: sample: let the cast functions set their output type
16204 - MINOR: sample: add a private field to the struct sample_conv
16205 - MINOR: map: Define map types
16206 - MEDIUM: sample: add the "map" converter
16207 - MEDIUM: http: The redirect strings follows the log format rules.
16208 - BUG/MINOR: acl: acl parser does not recognize empty converter list
16209 - BUG/MINOR: map: The map list was declared in the map.h file
16210 - MINOR: map: Cleanup the initialisation of map descriptors.
16211 - MEDIUM: map: merge identical maps
16212 - BUG/MEDIUM: pattern: Pattern node has type of "struct pat_idx_elt" in place of "struct eb_node"
16213 - BUG/MEDIUM: map: Bad map file parser
16214 - CLEANUP/MINOR: standard: use the system define INET6_ADDRSTRLEN in place of MAX_IP6_LEN
16215 - BUG/MEDIUM: sample: conversion from str to ipv6 may read data past end
16216 - MINOR: map: export map_get_reference() function
16217 - MINOR: pattern: Each pattern sets the expected input type
16218 - MEDIUM: acl: Last patch change the output type
16219 - MEDIUM: pattern: Extract the index process from the pat_parse_*() functions
16220 - MINOR: standard: The function parse_binary() can use preallocated buffer
16221 - MINOR: regex: Change the struct containing regex
16222 - MINOR: regex: Copy the original regex expression into string.
16223 - MINOR: pattern: add support for compiling patterns for lookups
16224 - MINOR: pattern: make the pattern matching function return a pointer to the matched element
16225 - MINOR: map: export parse output sample functions
16226 - MINOR: pattern: add function to lookup a specific entry in pattern list
16227 - MINOR: pattern/map: Each pattern must free the associated sample
16228 - MEDIUM: dumpstat: make the CLI parser understand the backslash as an escape char
16229 - MEDIUM: map: dynamic manipulation of maps
16230 - BUG/MEDIUM: unique_id: junk in log on empty unique_id
16231 - BUG/MINOR: log: junk at the end of syslog packet
16232 - MINOR: Makefile: provide cscope rule
16233 - DOC: compression: chunk are not compressed anymore
16234 - MEDIUM: session: disable lingering on the server when the client aborts
16235 - BUG/MEDIUM: prevent gcc from moving empty keywords lists into BSS
16236 - DOC: remove the comment saying that SSL certs are not checked on the server side
16237 - BUG: counters: third counter was not stored if others unset
16238 - BUG/MAJOR: http: don't emit the send-name-header when no server is available
16239 - BUG/MEDIUM: http: "option checkcache" fails with the no-cache header
16240 - BUG/MAJOR: http: sample prefetch code was not properly migrated
16241 - BUG/MEDIUM: splicing: fix abnormal CPU usage with splicing
16242 - BUG/MINOR: stream_interface: don't call chk_snd() on polled events
16243 - OPTIM: splicing: use splice() for the last block when relevant
16244 - MEDIUM: sample: handle comma-delimited converter list
16245 - MINOR: sample: fix sample_process handling of unstable data
16246 - CLEANUP: acl: move the 3 remaining sample fetches to samples.c
16247 - MINOR: sample: add a new "date" fetch to return the current date
16248 - MINOR: samples: add the http_date([<offset>]) sample converter.
16249 - DOC: minor improvements to the part on the stats socket.
16250 - MEDIUM: sample: systematically pass the keyword pointer to the keyword
16251 - MINOR: payload: split smp_fetch_rdp_cookie()
16252 - MINOR: counters: factor out smp_fetch_sc*_tracked
16253 - MINOR: counters: provide a generic function to retrieve a stkctr for sc* and src.
16254 - MEDIUM: counters: factor out smp_fetch_sc*_get_gpc0
16255 - MEDIUM: counters: factor out smp_fetch_sc*_gpc0_rate
16256 - MEDIUM: counters: factor out smp_fetch_sc*_inc_gpc0
16257 - MEDIUM: counters: factor out smp_fetch_sc*_clr_gpc0
16258 - MEDIUM: counters: factor out smp_fetch_sc*_conn_cnt
16259 - MEDIUM: counters: factor out smp_fetch_sc*_conn_rate
16260 - MEDIUM: counters: factor out smp_fetch_sc*_conn_cur
16261 - MEDIUM: counters: factor out smp_fetch_sc*_sess_cnt
16262 - MEDIUM: counters: factor out smp_fetch_sc*_sess_rate
16263 - MEDIUM: counters: factor out smp_fetch_sc*_http_req_cnt
16264 - MEDIUM: counters: factor out smp_fetch_sc*_http_req_rate
16265 - MEDIUM: counters: factor out smp_fetch_sc*_http_err_cnt
16266 - MEDIUM: counters: factor out smp_fetch_sc*_http_err_rate
16267 - MEDIUM: counters: factor out smp_fetch_sc*_kbytes_in
16268 - MEDIUM: counters: factor out smp_fetch_sc*_bytes_in_rate
16269 - MEDIUM: counters: factor out smp_fetch_sc*_kbytes_out
16270 - MEDIUM: counters: factor out smp_fetch_sc*_bytes_out_rate
16271 - MEDIUM: counters: factor out smp_fetch_sc*_trackers
16272 - MINOR: session: make the number of stick counter entries more configurable
16273 - MEDIUM: counters: support passing the counter number as a fetch argument
16274 - MEDIUM: counters: support looking up a key in an alternate table
16275 - MEDIUM: cli: adjust the method for feeding frequency counters in tables
16276 - MINOR: cli: make it possible to enter multiple values at once with "set table"
16277 - MINOR: payload: allow the payload sample fetches to retrieve arbitrary lengths
16278 - BUG/MINOR: cli: "clear table" must not kill entries that don't match condition
16279 - MINOR: ssl: use MAXPATHLEN instead of PATH_MAX
16280 - MINOR: config: warn when a server with no specific port uses rdp-cookie
16281 - BUG/MEDIUM: unique_id: HTTP request counter must be unique!
16282 - DOC: add a mention about the limited chunk size
16283 - BUG/MEDIUM: fix broken send_proxy on FreeBSD
16284 - MEDIUM: stick-tables: flush old entries upon soft-stop
16285 - MINOR: tcp: add new "close" action for tcp-response
16286 - MINOR: payload: provide the "res.len" fetch method
16287 - BUILD: add SSL_INC/SSL_LIB variables to force the path to openssl
16288 - MINOR: http: compute response time before processing headers
16289 - BUG/MINOR: acl: fix improper string size assignment in proxy argument
16290 - BUG/MEDIUM: http: accept full buffers on smp_prefetch_http
16291 - BUG/MINOR: acl: implicit arguments of ACL keywords were not properly resolved
16292 - BUG/MEDIUM: session: risk of crash on out of memory conditions
16293 - BUG/MINOR: peers: set the accept date in outgoing connections
16294 - BUG/MEDIUM: tcp: do not skip tracking rules on second pass
16295 - BUG/MEDIUM: acl: do not evaluate next terms after a miss
16296 - MINOR: acl: add a warning when an ACL keyword is used without any value
16297 - MINOR: tcp: don't use tick_add_ifset() when timeout is known to be set
16298 - BUG/MINOR: acl: remove patterns from the tree before freeing them
16299 - MEDIUM: backend: add support for the wt6 hash
16300 - OPTIM/MEDIUM: epoll: fuse active events into polled ones during polling changes
16301 - OPTIM/MINOR: mark the source address as already known on accept()
16302 - BUG/MINOR: stats: don't count tarpitted connections twice
16303 - CLEANUP: http: homogenize processing of denied req counter
16304 - CLEANUP: http: merge error handling for req* and http-request *
16305 - BUG/MEDIUM: http: fix possible parser crash when parsing erroneous "http-request redirect" rules
16306 - BUG/MINOR: http: fix build warning introduced with url32/url32_src
16307 - BUG/MEDIUM: checks: fix slow start regression after fix attempt
16308 - BUG/MAJOR: server: weight calculation fails for map-based algorithms
16309 - MINOR: stats: report correct throttling percentage for servers in slowstart
16310 - OPTIM: connection: fold the error handling with handshake handling
16311 - MINOR: peers: accept to learn strings of different lengths
16312 - BUG/MAJOR: fix haproxy crash when using server tracking instead of checks
16313 - BUG/MAJOR: check: fix haproxy crash during soft-stop/soft-start
16314 - BUG/MINOR: stats: do not report "via" on tracking servers in maintenance
16315 - BUG/MINOR: connection: fix typo in error message report
16316 - BUG/MINOR: backend: fix target address retrieval in transparent mode
16317 - BUG/MINOR: config: report the correct track-sc number in tcp-rules
16318 - BUG/MINOR: log: fix log-format parsing errors
16319 - DOC: add some information about how to apply converters to samples
16320 - MINOR: acl/pattern: use types different from int to clarify who does what.
16321 - MINOR: pattern: import acl_find_match_name() into pattern.h
16322 - MEDIUM: stick-tables: support automatic conversion from ipv4<->ipv6
16323 - MEDIUM: log-format: relax parsing of '%' followed by unsupported characters
16324 - BUG/MINOR: http: usual deinit stuff in last commit
16325 - BUILD: log: silent a warning about isblank() with latest patches
16326 - BUG/MEDIUM: checks: fix health check regression causing them to depend on declaration order
16327 - BUG/MEDIUM: checks: fix a long-standing issue with reporting connection errors
16328 - BUG/MINOR: checks: don't consider errno and use conn->err_code
16329 - BUG/MEDIUM: checks: also update the DRAIN state from the web interface
16330 - MINOR: stats: remove some confusion between the DRAIN state and NOLB
16331 - BUG/MINOR: tcp: check that no error is pending during a connect probe
16332 - BUG/MINOR: connection: check EINTR when sending a PROXY header
16333 - MEDIUM: connection: set the socket shutdown flags on socket errors
16334 - BUG/MEDIUM: acl: fix regression introduced by latest converters support
16335 - MINOR: connection: clear errno prior to checking for errors
16336 - BUG/MINOR: checks: do not trust errno in write event before any syscall
16337 - MEDIUM: checks: centralize error reporting
16338 - OPTIM: checks: don't poll on recv when using plain TCP connects
16339 - OPTIM: checks: avoid setting SO_LINGER twice
16340 - MINOR: tools: add a generic binary hex string parser
16341 - BUG/MEDIUM: checks: tcp-check: do not poll when there's nothing to send
16342 - BUG/MEDIUM: check: tcp-check might miss some outgoing data when socket buffers are full
16343 - BUG/MEDIUM: args: fix double free on error path in argument expression parser
16344 - BUG/MINOR: acl: fix sample expression error reporting
16345 - BUG/MINOR: checks: tcp-check actions are enums, not flags
16346 - MEDIUM: checks: make tcp-check perform multiple send() at once
16347 - BUG/MEDIUM: stick: completely remove the unused flag from the store entries
16348 - OPTIM: ebtree: pack the struct eb_node to avoid holes on 64-bit
16349 - BUG/MEDIUM: stick-tables: complete the latest fix about store-responses
16350 - CLEANUP: stream_interface: remove unused field err_loc
16351 - MEDIUM: stats: don't use conn->xprt_st anymore
16352 - MINOR: session: add a simple function to retrieve a session from a task
16353 - MEDIUM: stats: don't use conn->xprt_ctx anymore
16354 - MEDIUM: peers: don't rely on conn->xprt_ctx anymore
16355 - MINOR: http: prevent smp_fetch_url_{ip,port} from using si->conn
16356 - MINOR: connection: make it easier to emit proxy protocol for unknown addresses
16357 - MEDIUM: stats: prepare the HTTP stats I/O handler to support more states
16358 - MAJOR: stats: move the HTTP stats handling to its applet
16359 - MEDIUM: stats: move request argument processing to the final step
16360 - MEDIUM: session: detect applets from the session by using s->target
16361 - MAJOR: session: check for a connection to an applet in sess_prepare_conn_req()
16362 - MAJOR: session: pass applet return traffic through the response analysers
16363 - MEDIUM: stream-int: split the shutr/shutw functions between applet and conn
16364 - MINOR: stream-int: make the shutr/shutw functions void
16365 - MINOR: obj: provide a safe and an unsafe access to pointed objects
16366 - MINOR: connection: add a field to store an object type
16367 - MINOR: connection: always initialize conn->objt_type to OBJ_TYPE_CONN
16368 - MEDIUM: stream interface: move the peers' ptr into the applet context
16369 - MINOR: stream-interface: move the applet context to its own struct
16370 - MINOR: obj: introduce a new type appctx
16371 - MINOR: stream-int: rename ->applet to ->appctx
16372 - MINOR: stream-int: split si_prepare_embedded into si_prepare_none and si_prepare_applet
16373 - MINOR: stream-int: add a new pointer to the end point
16374 - MEDIUM: stream-interface: set the pointer to the applet into the applet context
16375 - MAJOR: stream interface: remove the ->release function pointer
16376 - MEDIUM: stream-int: make ->end point to the connection or the appctx
16377 - CLEANUP: stream-int: remove obsolete si_ctrl function
16378 - MAJOR: stream-int: stop using si->conn and use si->end instead
16379 - MEDIUM: stream-int: do not allocate a connection in parallel to applets
16380 - MEDIUM: session: attach incoming connection to target on embryonic sessions
16381 - MINOR: connection: add conn_init() to (re)initialize a connection
16382 - MINOR: checks: call conn_init() to properly initialize the connection.
16383 - MINOR: peers: make use of conn_init() to initialize the connection
16384 - MINOR: session: use conn_init() to initialize the connections
16385 - MINOR: http: use conn_init() to reinitialize the server connection
16386 - MEDIUM: connection: replace conn_prepare with conn_assign
16387 - MINOR: get rid of si_takeover_conn()
16388 - MINOR: connection: add conn_new() / conn_free()
16389 - MAJOR: connection: add two new flags to indicate readiness of control/transport
16390 - MINOR: stream-interface: introduce si_reset() and si_set_state()
16391 - MINOR: connection: reintroduce conn_prepare to set the protocol and transport
16392 - MINOR: connection: replace conn_assign with conn_attach
16393 - MEDIUM: stream-interface: introduce si_attach_conn to replace si_prepare_conn
16394 - MAJOR: stream interface: dynamically allocate the outgoing connection
16395 - MEDIUM: connection: move the send_proxy offset to the connection
16396 - MINOR: connection: check for send_proxy during the connect(), not the SI
16397 - MEDIUM: connection: merge the send_proxy and local_send_proxy calls
16398 - MEDIUM: stream-int: replace occurrences of si->appctx with si_appctx()
16399 - MEDIUM: stream-int: return the allocated appctx in stream_int_register_handler()
16400 - MAJOR: stream-interface: dynamically allocate the applet context
16401 - MEDIUM: session: automatically register the applet designated by the target
16402 - MEDIUM: stats: delay appctx initialization
16403 - CLEANUP: peers: use less confusing state/status code names
16404 - MEDIUM: peers: delay appctx initialization
16405 - MINOR: stats: provide some appctx information in "show sess all"
16406 - DIET/MINOR: obj: pack the obj_type enum to 8 bits
16407 - DIET/MINOR: connection: rearrange a few fields to save 8 bytes in the struct
16408 - DIET/MINOR: listener: rearrange a few fields in struct listener to save 16 bytes
16409 - DIET/MINOR: proxy: rearrange a few fields in struct proxy to save 16 bytes
16410 - DIET/MINOR: session: reduce the struct session size by 8 bytes
16411 - DIET/MINOR: stream-int: rearrange a few fields in struct stream_interface to save 8 bytes
16412 - DIET/MINOR: http: reduce the size of struct http_txn by 8 bytes
16413 - MINOR: http: switch the http state to an enum
16414 - MINOR: http: use an enum for the auth method in http_auth_data
16415 - DIET/MINOR: task: reduce struct task size by 8 bytes
16416 - MINOR: stream_interface: add reporting of ressouce allocation errors
16417 - MINOR: session: report lack of resources using the new stream-interface's error code
16418 - BUILD: simplify the date and version retrieval in the makefile
16419 - BUILD: prepare the makefile to skip format lines in SUBVERS and VERDATE
16420 - BUILD: use format tags in VERDATE and SUBVERS files
16421 - BUG/MEDIUM: channel: bo_getline() must wait for \n until buffer is full
16422 - CLEANUP: check: server port is unsigned
16423 - BUG/MEDIUM: checks: agent doesn't get the response if server does not closes
16424 - MINOR: tools: buf2ip6 must not modify output on failure
16425 - MINOR: pattern: do not assign SMP_TYPES by default to patterns
16426 - MINOR: sample: make sample_parse_expr() use memprintf() to report parse errors
16427 - MINOR: arg: improve wording on error reporting
16428 - BUG/MEDIUM: sample: simplify and fix the argument parsing
16429 - MEDIUM: acl: fix the argument parser to let the lower layer report detailed errors
16430 - MEDIUM: acl: fix the initialization order of the ACL expression
16431 - CLEANUP: acl: remove useless blind copy-paste from sample converters
16432 - TESTS: add regression tests for ACL and sample expression parsers
16433 - BUILD: time: adapt the type of TV_ETERNITY to the local system
16434 - MINOR: chunks: allocate the trash chunks before parsing the config
16435 - BUILD: definitely silence some stupid GCC warnings
16436 - MINOR: chunks: always initialize the output chunk in get_trash_chunk()
16437 - MINOR: checks: improve handling of the servers tracking chain
16438 - REORG: checks: retrieve the check-specific defines from server.h to checks.h
16439 - MINOR: checks: use an enum instead of flags to report a check result
16440 - MINOR: checks: rename the state flags
16441 - MINOR: checks: replace state DISABLED with CONFIGURED and ENABLED
16442 - MINOR: checks: use check->state instead of srv->state & SRV_CHECKED
16443 - MINOR: checks: fix agent check interval computation
16444 - MINOR: checks: add a PAUSED state for the checks
16445 - MINOR: checks: create the agent tasks even when no check is configured
16446 - MINOR: checks: add a flag to indicate what check is an agent
16447 - MEDIUM: checks: enable agent checks even if health checks are disabled
16448 - BUG/MEDIUM: checks: ensure we can enable a server after boot
16449 - BUG/MEDIUM: checks: tracking servers must not inherit the MAINT flag
16450 - BUG/MAJOR: session: repair tcp-request connection rules
16451 - BUILD: fix SUBVERS extraction in the Makefile
16452 - BUILD: pattern: silence a warning about uninitialized value
16453 - BUILD: log: fix build warning on Solaris
16454 - BUILD: dumpstats: fix build error on Solaris
16455 - DOC: move option pgsql-check to the correct place
16456 - DOC: move option tcp-check to the proper place
16457 - MINOR: connection: add simple functions to report connection readiness
16458 - MEDIUM: connection: centralize handling of nolinger in fd management
16459 - OPTIM: http: set CF_READ_DONTWAIT on response message
16460 - OPTIM: http: do not re-enable reading on client side while closing the server side
16461 - MINOR: config: add option http-keep-alive
16462 - MEDIUM: connection: inform si_alloc_conn() whether existing conn is OK or not
16463 - MAJOR: stream-int: handle the connection reuse in si_connect()
16464 - MAJOR: http: add the keep-alive transition on the server side
16465 - MAJOR: backend: enable connection reuse
16466 - MINOR: http: add option prefer-last-server
16467 - MEDIUM: http: do not report connection errors for second and further requests
16468
Willy Tarreaueab1dc62013-06-17 15:10:25 +0200164692013/06/17 : 1.5-dev19
16470 - MINOR: stats: remove the autofocus on the scope input field
16471 - BUG/MEDIUM: Fix crt-list file parsing error: filtered name was ignored.
16472 - BUG/MEDIUM: ssl: EDH ciphers are not usable if no DH parameters present in pem file.
16473 - BUG/MEDIUM: shctx: makes the code independent on SSL runtime version.
16474 - MEDIUM: ssl: improve crt-list format to support negation
16475 - BUG: ssl: fix crt-list for clients not supporting SNI
16476 - MINOR: stats: show soft-stopped servers in different color
16477 - BUG/MINOR: config: "source" does not work in defaults section
16478 - BUG: regex: fix pcre compile error when using JIT
16479 - MINOR: ssl: add pattern fetch 'ssl_c_sha1'
16480 - BUG: ssl: send payload gets corrupted if tune.ssl.maxrecord is used
16481 - MINOR: show PCRE version and JIT status in -vv
16482 - BUG/MINOR: jit: don't rely on USE flag to detect support
16483 - DOC: readme: add suggestion to link against static openssl
16484 - DOC: examples: provide simplified ssl configuration
16485 - REORG: tproxy: prepare the transparent proxy defines for accepting other OSes
16486 - MINOR: tproxy: add support for FreeBSD
16487 - MINOR: tproxy: add support for OpenBSD
16488 - DOC: examples: provide an example of transparent proxy configuration for FreeBSD 8
16489 - CLEANUP: fix minor typo in error message.
16490 - CLEANUP: fix missing include <string.h> in proto/listener.h
16491 - CLEANUP: protect checks.h from multiple inclusions
16492 - MINOR: compression: acl "res.comp" and fetch "res.comp_algo"
16493 - BUG/MINOR: http: add-header/set-header did not accept the ACL condition
16494 - BUILD: mention in the Makefile that USE_PCRE_JIT is for libpcre >= 8.32
16495 - BUG/MEDIUM: splicing is broken since 1.5-dev12
16496 - BUG/MAJOR: acl: add implicit arguments to the resolve list
16497 - BUG/MINOR: tcp: fix error reporting for TCP rules
16498 - CLEANUP: peers: remove a bit of spaghetti to prepare for the next bugfix
16499 - MINOR: stick-table: allow to allocate an entry without filling it
16500 - BUG/MAJOR: peers: fix an overflow when syncing strings larger than 16 bytes
16501 - MINOR: session: only call http_send_name_header() when changing the server
16502 - MINOR: tcp: report the erroneous word in tcp-request track*
16503 - BUG/MAJOR: backend: consistent hash can loop forever in certain circumstances
16504 - BUG/MEDIUM: log: fix regression on log-format handling
16505 - MEDIUM: log: report file name, line number, and directive name with log-format errors
16506 - BUG/MINOR: cli: "clear table" did not work anymore without a key
16507 - BUG/MINOR: cli: "clear table xx data.xx" does not work anymore
16508 - BUG/MAJOR: http: compression still has defects on chunked responses
16509 - BUG/MINOR: stats: fix confirmation links on the stats interface
16510 - BUG/MINOR: stats: the status bar does not appear anymore after a change
16511 - BUG/MEDIUM: stats: allocate the stats frontend also on "stats bind-process"
16512 - BUG/MEDIUM: stats: fix a regression when dealing with POST requests
16513 - BUG/MINOR: fix unterminated ACL array in compression
16514 - BUILD: last fix broke non-linux platforms
16515 - MINOR: init: indicate the SSL runtime version on -vv.
16516 - BUG/MEDIUM: compression: the deflate algorithm must use global settings as well
16517 - BUILD: stdbool is not portable (again)
16518 - DOC: readme: add a small reminder about restrictions to respect in the code
16519 - MINOR: ebtree: add new eb_next_dup/eb_prev_dup() functions to visit duplicates
16520 - BUG/MINOR: acl: fix a double free during exit when using PCRE_JIT
16521 - DOC: fix wrong copy-paste in the rspdel example
16522 - MINOR: counters: make it easier to extend the amount of tracked counters
16523 - MEDIUM: counters: add support for tracking a third counter
16524 - MEDIUM: counters: add a new "gpc0_rate" counter in stick-tables
16525 - BUG/MAJOR: http: always ensure response buffer has some room for a response
16526 - MINOR: counters: add fetch/acl sc*_tracked to indicate whether a counter is tracked
16527 - MINOR: defaults: allow REQURI_LEN and CAPTURE_LEN to be redefined
16528 - MINOR: log: add a new flag 'L' for locally processed requests
16529 - MINOR: http: add full-length header fetch methods
16530 - MEDIUM: protocol: implement a "drain" function in protocol layers
16531 - MEDIUM: http: add a new "http-response" ruleset
16532 - MEDIUM: http: add the "set-nice" action to http-request and http-response
16533 - MEDIUM: log: add a log level override value in struct session
16534 - MEDIUM: http: add support for action "set-log-level" in http-request/http-response
16535 - MEDIUM: http: add support for "set-tos" in http-request/http-response
16536 - MEDIUM: http: add the "set-mark" action on http-request/http-response rules
16537 - MEDIUM: tcp: add "tcp-request connection expect-proxy layer4"
16538 - MEDIUM: acl: automatically detect the type of certain fetches
16539 - MEDIUM: acl: remove a lot of useless ACLs that are equivalent to their fetches
16540 - MEDIUM: acl: remove 15 additional useless ACLs that are equivalent to their fetches
16541 - DOC: major reorg of ACL + sample fetch
16542 - CLEANUP: http: remove the bogus urlp_ip ACL match
16543 - MINOR: acl: add the new "env()" fetch method to retrieve an environment variable
16544 - BUG/MINOR: acl: correctly consider boolean fetches when doing casts
16545 - BUG/CRITICAL: fix a possible crash when using negative header occurrences
16546 - DOC: update ROADMAP file
16547 - MEDIUM: counters: use sc0/sc1/sc2 instead of sc1/sc2/sc3
16548 - MEDIUM: stats: add proxy name filtering on the statistic page
16549
Willy Tarreau289dd922013-04-03 02:26:31 +0200165502013/04/03 : 1.5-dev18
16551 - DOCS: Add explanation of intermediate certs to crt paramater
16552 - DOC: typo and minor fixes in compression paragraph
16553 - MINOR: config: http-request configuration error message misses new keywords
16554 - DOC: minor typo fix in documentation
16555 - BUG/MEDIUM: ssl: ECDHE ciphers not usable without named curve configured.
16556 - MEDIUM: ssl: add bind-option "strict-sni"
16557 - MEDIUM: ssl: add mapping from SNI to cert file using "crt-list"
16558 - MEDIUM: regex: Use PCRE JIT in acl
16559 - DOC: simplify bind option "interface" explanation
16560 - DOC: tfo: bump required kernel to linux-3.7
16561 - BUILD: add explicit support for TFO with USE_TFO
16562 - MEDIUM: New cli option -Ds for systemd compatibility
16563 - MEDIUM: add haproxy-systemd-wrapper
16564 - MEDIUM: add systemd service
16565 - BUG/MEDIUM: systemd-wrapper: don't leak zombie processes
16566 - BUG/MEDIUM: remove supplementary groups when changing gid
16567 - BUG/MEDIUM: config: fix parser crash with bad bind or server address
16568 - BUG/MINOR: Correct logic in cut_crlf()
16569 - CLEANUP: checks: Make desc argument to set_server_check_status const
16570 - CLEANUP: dumpstats: Make cli_release_handler() static
16571 - MEDIUM: server: Break out set weight processing code
16572 - MEDIUM: server: Allow relative weights greater than 100%
16573 - MEDIUM: server: Tighten up parsing of weight string
16574 - MEDIUM: checks: Add agent health check
16575 - BUG/MEDIUM: ssl: openssl 0.9.8 doesn't open /dev/random before chroot
16576 - BUG/MINOR: time: frequency counters are not totally accurate
16577 - BUG/MINOR: http: don't process abortonclose when request was sent
16578 - BUG/MEDIUM: stream_interface: don't close outgoing connections on shutw()
16579 - BUG/MEDIUM: checks: ignore late resets after valid responses
16580 - DOC: fix bogus recommendation on usage of gpc0 counter
16581 - BUG/MINOR: http-compression: lookup Cache-Control in the response, not the request
16582 - MINOR: signal: don't block SIGPROF by default
16583 - OPTIM: epoll: make use of EPOLLRDHUP
16584 - OPTIM: splice: detect shutdowns and avoid splice() == 0
16585 - OPTIM: splice: assume by default that splice is working correctly
16586 - BUG/MINOR: log: temporary fix for lost SSL info in some situations
16587 - BUG/MEDIUM: peers: only the last peers section was used by tables
16588 - BUG/MEDIUM: config: verbosely reject peers sections with multiple local peers
16589 - BUG/MINOR: epoll: use a fix maxevents argument in epoll_wait()
16590 - BUG/MINOR: config: fix improper check for failed memory alloc in ACL parser
16591 - BUG/MINOR: config: free peer's address when exiting upon parsing error
16592 - BUG/MINOR: config: check the proper variable when parsing log minlvl
16593 - BUG/MEDIUM: checks: ensure the health_status is always within bounds
16594 - BUG/MINOR: cli: show sess should always validate s->listener
16595 - BUG/MINOR: log: improper NULL return check on utoa_pad()
16596 - CLEANUP: http: remove a useless null check
16597 - CLEANUP: tcp/unix: remove useless NULL check in {tcp,unix}_bind_listener()
16598 - BUG/MEDIUM: signal: signal handler does not properly check for signal bounds
16599 - BUG/MEDIUM: tools: off-by-one in quote_arg()
16600 - BUG/MEDIUM: uri_auth: missing NULL check and memory leak on memory shortage
16601 - BUG/MINOR: unix: remove the 'level' field from the ux struct
16602 - CLEANUP: http: don't try to deinitialize http compression if it fails before init
16603 - CLEANUP: config: slowstart is never negative
16604 - CLEANUP: config: maxcompcpuusage is never negative
16605 - BUG/MEDIUM: log: emit '-' for empty fields again
16606 - BUG/MEDIUM: checks: fix a race condition between checks and observe layer7
16607 - BUILD: fix a warning emitted by isblank() on non-c99 compilers
16608 - BUILD: improve the makefile's support for libpcre
16609 - MEDIUM: halog: add support for counting per source address (-ic)
16610 - MEDIUM: tools: make str2sa_range support all address syntaxes
16611 - MEDIUM: config: make use of str2sa_range() instead of str2sa()
16612 - MEDIUM: config: use str2sa_range() to parse server addresses
16613 - MEDIUM: config: use str2sa_range() to parse peers addresses
16614 - MINOR: tests: add a config file to ease address parsing tests.
16615 - MINOR: ssl: add a global tunable for the max SSL/TLS record size
16616 - BUG/MINOR: syscall: fix NR_accept4 system call on sparc/linux
16617 - BUILD/MINOR: syscall: add definition of NR_accept4 for ARM
16618 - MINOR: config: report missing peers section name
16619 - BUG/MEDIUM: tools: fix bad character handling in str2sa_range()
16620 - BUG/MEDIUM: stats: never apply "unix-bind prefix" to the global stats socket
16621 - MINOR: tools: prepare str2sa_range() to return an error message
16622 - BUG/MEDIUM: checks: don't call connect() on unsupported address families
16623 - MINOR: tools: prepare str2sa_range() to accept a prefix
16624 - MEDIUM: tools: make str2sa_range() parse unix addresses too
16625 - MEDIUM: config: make str2listener() use str2sa_range() to parse unix addresses
16626 - MEDIUM: config: use a single str2sa_range() call to parse bind addresses
16627 - MEDIUM: config: use str2sa_range() to parse log addresses
16628 - CLEANUP: tools: remove str2sun() which is not used anymore.
16629 - MEDIUM: config: add complete support for str2sa_range() in dispatch
16630 - MEDIUM: config: add complete support for str2sa_range() in server addr
16631 - MEDIUM: config: add complete support for str2sa_range() in 'server'
16632 - MEDIUM: config: add complete support for str2sa_range() in 'peer'
16633 - MEDIUM: config: add complete support for str2sa_range() in 'source' and 'usesrc'
16634 - CLEANUP: minor cleanup in str2sa_range() and str2ip()
16635 - CLEANUP: config: do not use multiple errmsg at once
16636 - MEDIUM: tools: support specifying explicit address families in str2sa_range()
16637 - MAJOR: listener: support inheriting a listening fd from the parent
16638 - MAJOR: tools: support environment variables in addresses
16639 - BUG/MEDIUM: http: add-header should not emit "-" for empty fields
16640 - BUG/MEDIUM: config: ACL compatibility check on "redirect" was wrong
16641 - BUG/MEDIUM: http: fix another issue caused by http-send-name-header
16642 - DOC: mention the new HTTP 307 and 308 redirect statues
16643 - MEDIUM: poll: do not use FD_* macros anymore
16644 - BUG/MAJOR: ev_select: disable the select() poller if maxsock > FD_SETSIZE
16645 - BUG/MINOR: acl: ssl_fc_{alg,use}_keysize must parse integers, not strings
16646 - BUG/MINOR: acl: ssl_c_used, ssl_fc{,_has_crt,_has_sni} take no pattern
16647 - BUILD: fix usual isdigit() warning on solaris
16648 - BUG/MEDIUM: tools: vsnprintf() is not always reliable on Solaris
16649 - OPTIM: buffer: remove one jump in buffer_count()
16650 - OPTIM: http: improve branching in chunk size parser
16651 - OPTIM: http: optimize the response forward state machine
16652 - BUILD: enable poll() by default in the makefile
16653 - BUILD: add explicit support for Mac OS/X
16654 - BUG/MAJOR: http: use a static storage for sample fetch context
16655 - BUG/MEDIUM: ssl: improve error processing and reporting in ssl_sock_load_cert_list_file()
16656 - BUG/MAJOR: http: fix regression introduced by commit a890d072
16657 - BUG/MAJOR: http: fix regression introduced by commit d655ffe
16658 - BUG/CRITICAL: using HTTP information in tcp-request content may crash the process
16659 - MEDIUM: acl: remove flag ACL_MAY_LOOKUP which is improperly used
16660 - MEDIUM: samples: use new flags to describe compatibility between fetches and their usages
16661 - MINOR: log: indicate it when some unreliable sample fetches are logged
16662 - MEDIUM: samples: move payload-based fetches and ACLs to their own file
16663 - MINOR: backend: rename sample fetch functions and declare the sample keywords
16664 - MINOR: frontend: rename sample fetch functions and declare the sample keywords
16665 - MINOR: listener: rename sample fetch functions and declare the sample keywords
16666 - MEDIUM: http: unify acl and sample fetch functions
16667 - MINOR: session: rename sample fetch functions and declare the sample keywords
16668 - MAJOR: acl: make all ACLs reference the fetch function via a sample.
16669 - MAJOR: acl: remove the arg_mask from the ACL definition and use the sample fetch's
16670 - MAJOR: acl: remove fetch argument validation from the ACL struct
16671 - MINOR: http: add new direction-explicit sample fetches for headers and cookies
16672 - MINOR: payload: add new direction-explicit sample fetches
16673 - CLEANUP: acl: remove ACL hooks which were never used
16674 - MEDIUM: proxy: remove acl_requires and just keep a flag "http_needed"
16675 - MINOR: sample: provide a function to report the name of a sample check point
16676 - MAJOR: acl: convert all ACL requires to SMP use+val instead of ->requires
16677 - CLEANUP: acl: remove unused references to ACL_USE_*
16678 - MINOR: http: replace acl_parse_ver with acl_parse_str
16679 - MEDIUM: acl: move the ->parse, ->match and ->smp fields to acl_expr
16680 - MAJOR: acl: add option -m to change the pattern matching method
16681 - MINOR: acl: remove the use_count in acl keywords
16682 - MEDIUM: acl: have a pointer to the keyword name in acl_expr
16683 - MEDIUM: acl: support using sample fetches directly in ACLs
16684 - MEDIUM: http: remove val_usr() to validate user_lists
16685 - MAJOR: sample: maintain a per-proxy list of the fetch args to resolve
16686 - MINOR: ssl: add support for the "alpn" bind keyword
16687 - MINOR: http: status code 303 is HTTP/1.1 only
16688 - MEDIUM: http: implement redirect 307 and 308
16689 - MINOR: http: status 301 should not be marked non-cacheable
16690
Willy Tarreaua3ecbd92012-12-28 15:04:05 +0100166912012/12/28 : 1.5-dev17
16692 - MINOR: ssl: Setting global tune.ssl.cachesize value to 0 disables SSL session cache.
16693 - BUG/MEDIUM: stats: fix stats page regression introduced by commit 20b0de5
16694 - BUG/MINOR: stats: last fix was still wrong
16695 - BUG/MINOR: stats: http-request rules still don't cope with stats
16696 - BUG/MINOR: http: http-request add-header emits a corrupted header
16697 - BUG/MEDIUM: stats: disable request analyser when processing POST or HEAD
16698 - BUG/MINOR: log: make log-format, unique-id-format and add-header more independant
16699 - BUILD: log: unused variable svid
16700 - CLEANUP: http: rename the misleading http_check_access_rule
16701 - MINOR: http: move redirect rule processing to its own function
16702 - REORG: config: move the http redirect rule parser to proto_http.c
16703 - MEDIUM: http: add support for "http-request redirect" rules
16704 - MEDIUM: http: add support for "http-request tarpit" rule
16705
Willy Tarreau69eda352012-12-24 16:48:14 +0100167062012/12/24 : 1.5-dev16
16707 - BUG/MEDIUM: ssl: Prevent ssl error from affecting other connections.
16708 - BUG/MINOR: ssl: error is not reported if it occurs simultaneously with peer close detection.
16709 - MINOR: ssl: add fetch and acl "ssl_c_used" to check if current SSL session uses a client certificate.
16710 - MINOR: contrib: make the iprange tool grep for addresses
16711 - CLEANUP: polling: gcc doesn't always optimize constants away
16712 - OPTIM: poll: optimize fd management functions for low register count CPUs
16713 - CLEANUP: poll: remove a useless double-check on fdtab[fd].owner
16714 - OPTIM: epoll: use a temp variable for intermediary flag computations
16715 - OPTIM: epoll: current fd does not count as a new one
16716 - BUG/MINOR: poll: the I/O handler was called twice for polled I/Os
16717 - MINOR: http: make resp_ver and status ACLs check for the presence of a response
16718 - BUG/MEDIUM: stream-interface: fix possible stalls during transfers
16719 - BUG/MINOR: stream_interface: don't return when the fd is already set
16720 - BUG/MEDIUM: connection: always update connection flags prior to computing polling
16721 - CLEANUP: buffer: use buffer_empty() instead of buffer_len()==0
16722 - BUG/MAJOR: stream_interface: fix occasional data transfer freezes
16723 - BUG/MEDIUM: stream_interface: fix another case where the reader might not be woken up
16724 - BUG/MINOR: http: don't abort client connection on premature responses
16725 - BUILD: no need to clean up when making git-tar
16726 - MINOR: log: add a tag for amount of bytes uploaded from client to server
16727 - BUG/MEDIUM: log: fix possible segfault during config parsing
16728 - MEDIUM: log: change a few log tokens to make them easier to remember
16729 - BUG/MINOR: log: add_to_logformat_list() used the wrong constants
16730 - MEDIUM: log-format: make the format parser more robust and more extensible
16731 - MINOR: sample: support cast from bool to string
16732 - MINOR: samples: add a function to fetch and convert any sample to a string
16733 - MINOR: log: add lf_text_len
16734 - MEDIUM: log: add the ability to include samples in logs
16735 - REORG: stats: massive code reorg and cleanup
16736 - REORG: stats: move the HTTP header injection to proto_http
16737 - REORG: stats: functions are now HTTP/CLI agnostic
16738 - BUG/MINOR: log: fix regression introduced by commit 8a3f52
16739 - MINOR: chunks: centralize the trash chunk allocation
16740 - MEDIUM: stats: use hover boxes instead of title to report details
16741 - MEDIUM: stats: use multi-line tips to display detailed counters
16742 - MINOR: tools: simplify the use of the int to ascii macros
16743 - MINOR: stats: replace STAT_FMT_CSV with STAT_FMT_HTML
16744 - MINOR: http: prepare to support more http-request actions
16745 - MINOR: log: make parse_logformat_string() take a const char *
16746 - MEDIUM: http: add http-request 'add-header' and 'set-header' to build headers
16747
Willy Tarreau0cae4b32012-12-12 00:39:52 +0100167482012/12/12 : 1.5-dev15
16749 - DOC: add a few precisions on compression
16750 - BUG/MEDIUM: ssl: Fix handshake failure on session resumption with client cert.
16751 - BUG/MINOR: ssl: One free session in cache remains unused.
16752 - BUG/MEDIUM: ssl: first outgoing connection would fail with {ca,crt}-ignore-err
16753 - MEDIUM: ssl: manage shared cache by blocks for huge sessions.
16754 - MINOR: acl: add fetch for server session rate
16755 - BUG/MINOR: compression: Content-Type is case insensitive
16756 - MINOR: compression: disable on multipart or status != 200
16757 - BUG/MINOR: http: don't report client aborts as server errors
16758 - MINOR: stats: compute the ratio of compressed response based on 2xx responses
16759 - MINOR: http: factor out the content-type checks
16760 - BUG/MAJOR: stats: correctly check for a possible divide error when showing compression ratios
16761 - BUILD: ssl: OpenSSL 0.9.6 has no renegociation
16762 - BUG/MINOR: http: disable compression when message has no body
16763 - MINOR: compression: make the stats a bit more robust
16764 - BUG/MEDIUM: comp: DEFAULT_MAXZLIBMEM was expressed in bytes and not megabytes
16765 - MINOR: connection: don't remove failed handshake flags
16766 - MEDIUM: connection: add an error code in connections
16767 - MEDIUM: connection: add minimal error reporting in logs for incomplete connections
16768 - MEDIUM: connection: add error reporting for the PROXY protocol header
16769 - MEDIUM: connection: add error reporting for the SSL
16770 - DOC: document the connection error format in logs
16771 - BUG/MINOR: http: don't log a 503 on client errors while waiting for requests
16772 - BUILD: stdbool is not portable
16773 - BUILD: ssl: NAME_MAX is not portable, use MAXPATHLEN instead
16774 - BUG/MAJOR: raw_sock: must check error code on hangup
16775 - BUG/MAJOR: polling: do not set speculative events on ERR nor HUP
16776 - BUG/MEDIUM: session: fix FD leak when transport layer logging is enabled
16777 - MINOR: stats: add a few more information on session dump
16778 - BUG/MINOR: tcp: set the ADDR_TO_SET flag on outgoing connections
16779 - CLEANUP: connection: remove unused server/proxy/task/si_applet declarations
16780 - BUG/MEDIUM: tcp: process could theorically crash on lack of source ports
16781 - MINOR: cfgparse: mention "interface" in the list of allowed "source" options
16782 - MEDIUM: connection: introduce "struct conn_src" for servers and proxies
16783 - CLEANUP: proto_tcp: use the same code to bind servers and backends
16784 - CLEANUP: backend: use the same tproxy address selection code for servers and backends
16785 - BUG/MEDIUM: stick-tables: conversions to strings were broken in dev13
16786 - MEDIUM: proto_tcp: add support for tracking L7 information
16787 - MEDIUM: counters: add sc1_trackers/sc2_trackers
16788 - MINOR: http: add the "base32" pattern fetch function
16789 - MINOR: http: add the "base32+src" fetch method.
16790 - CLEANUP: session: use an array for the stick counters
16791 - BUG/MINOR: proto_tcp: fix parsing of "table" in track-sc1/2
16792 - BUG/MINOR: proto_tcp: bidirectional fetches not supported anymore in track-sc1/2
16793 - BUG/MAJOR: connection: always recompute polling status upon I/O
16794 - BUG/MINOR: connection: remove a few synchronous calls to polling updates
16795 - MINOR: config: improve error checking on TCP stick-table tracking
16796 - DOC: add some clarifications to the readme
16797
Willy Tarreaufee48ce2012-11-26 03:11:05 +0100167982012/11/26 : 1.5-dev14
16799 - DOC: fix minor typos
16800 - BUG/MEDIUM: compression: does not forward trailers
16801 - MINOR: buffer_dump with ASCII
16802 - BUG/MEDIUM: checks: mark the check as stopped after a connect error
16803 - BUG/MEDIUM: checks: ensure we completely disable polling upon success
16804 - BUG/MINOR: checks: don't mark the FD as closed before transport close
16805 - MEDIUM: checks: avoid accumulating TIME_WAITs during checks
16806 - MINOR: cli: report the msg state in full text in "show sess $PTR"
16807 - CLEANUP: checks: rename some server check flags
16808 - MAJOR: checks: rework completely bogus state machine
16809 - BUG/MINOR: checks: slightly clean the state machine up
16810 - MEDIUM: checks: avoid waking the application up for pure TCP checks
16811 - MEDIUM: checks: close the socket as soon as we have a response
16812 - BUG/MAJOR: checks: close FD on all timeouts
16813 - MINOR: checks: fix recv polling after connect()
16814 - MEDIUM: connection: provide a common conn_full_close() function
16815 - BUG/MEDIUM: checks: prevent TIME_WAITs from appearing also on timeouts
16816 - BUG/MAJOR: peers: the listener's maxaccept was not set and caused loops
16817 - MINOR: listeners: make the accept loop more robust when maxaccept==0
16818 - BUG/MEDIUM: acl: correctly resolve all args, not just the first one
16819 - BUG/MEDIUM: acl: make prue_acl_expr() correctly free ACL expressions upon exit
16820 - BUG/MINOR: stats: fix inversion of the report of a check in progress
16821 - MEDIUM: tcp: add explicit support for delayed ACK in connect()
16822 - BUG/MEDIUM: connection: always disable polling upon error
16823 - MINOR: connection: abort earlier when errors are detected
16824 - BUG/MEDIUM: checks: report handshake failures
16825 - BUG/MEDIUM: connection: local_send_proxy must wait for connection to establish
16826 - MINOR: tcp: add support for the "v6only" bind option
16827 - MINOR: stats: also report the computed compression savings in html stats
16828 - MINOR: stats: report the total number of compressed responses per front/back
16829 - MINOR: tcp: add support for the "v4v6" bind option
16830 - DOC: stats: document the comp_rsp stats column
16831 - BUILD: buffer: fix another isprint() warning on solaris
16832 - MINOR: cli: add support for the "show sess all" command
16833 - BUG/MAJOR: cli: show sess <id> may randomly corrupt the back-ref list
16834 - MINOR: cli: improve output format for show sess $ptr
16835
Willy Tarreauad15d122012-11-22 01:11:33 +0100168362012/11/22 : 1.5-dev13
16837 - BUILD: fix build issue without USE_OPENSSL
16838 - BUILD: fix compilation error with DEBUG_FULL
16839 - DOC: ssl: remove prefer-server-ciphers documentation
16840 - DOC: ssl: surround keywords with quotes
16841 - DOC: fix minor typo on http-send-name-header
16842 - BUG/MEDIUM: acls using IPv6 subnets patterns incorrectly match IPs
16843 - BUG/MAJOR: fix a segfault on option http_proxy and url_ip acl
16844 - MEDIUM: http: accept IPv6 values with (s)hdr_ip acl
16845 - BUILD: report zlib support in haproxy -vv
16846 - DOC: compression: add some details and clean up the formatting
16847 - DOC: Change is_ssl acl to ssl_fc acl in example
16848 - DOC: make it clear what the HTTP request size is
16849 - MINOR: ssl: try to load Diffie-Hellman parameters from cert file
16850 - DOC: ssl: update 'crt' statement on 'bind' about Diffie-Hellman parameters loading
16851 - MINOR: ssl: add elliptic curve Diffie-Hellman support for ssl key generation
16852 - DOC: ssl: add 'ecdhe' statement on 'bind'
16853 - MEDIUM: ssl: add client certificate authentication support
16854 - DOC: ssl: add 'verify', 'cafile' and 'crlfile' statements on 'bind'
16855 - MINOR: ssl: add fetch and ACL 'client_crt' to test a client cert is present
16856 - DOC: ssl: add fetch and ACL 'client_cert'
16857 - MINOR: ssl: add ignore verify errors options
16858 - DOC: ssl: add 'ca-ignore-err' and 'crt-ignore-err' statements on 'bind'
16859 - MINOR: ssl: add fetch and ACL 'ssl_verify_result'
16860 - DOC: ssl: add fetch and ACL 'ssl_verify_result'
16861 - MINOR: ssl: add fetches and ACLs to return verify errors
16862 - DOC: ssl: add fetches and ACLs 'ssl_verify_crterr', 'ssl_verify_caerr', and 'ssl_verify_crterr_depth'
16863 - MINOR: ssl: disable shared memory and locks on session cache if nbproc == 1
16864 - MINOR: ssl: add build param USE_PRIVATE_CACHE to build cache without shared memory
16865 - MINOR: ssl : add statements 'notlsv11' and 'notlsv12' and rename 'notlsv1' to 'notlsv10'.
16866 - DOC: ssl : add statements 'notlsv11' and 'notlsv12' and rename 'notlsv1' to 'notlsv10'.
16867 - MEDIUM: config: authorize frontend and listen without bind.
16868 - MINOR: ssl: add statement 'no-tls-tickets' on bind to disable stateless session resumption
16869 - DOC: ssl: add 'no-tls-tickets' statement documentation.
16870 - BUG/MINOR: ssl: Fix CRL check was not enabled when crlfile was specified.
16871 - BUG/MINOR: build: Fix compilation issue on openssl 0.9.6 due to missing CRL feature.
16872 - BUG/MINOR: conf: Fix 'maxsslconn' statement error if built without OPENSSL.
16873 - BUG/MINOR: build: Fix failure with USE_OPENSSL=1 and USE_FUTEX=1 on archs i486 and i686.
16874 - MINOR: ssl: remove prefer-server-ciphers statement and set it as the default on ssl listeners.
16875 - BUG/MEDIUM: ssl: subsequent handshakes fail after server configuration changes
16876 - MINOR: ssl: add 'crt-base' and 'ca-base' global statements.
16877 - MEDIUM: conf: rename 'nosslv3' and 'notlsvXX' statements 'no-sslv3' and 'no-tlsvXX'.
16878 - MEDIUM: conf: rename 'cafile' and 'crlfile' statements 'ca-file' and 'crl-file'
16879 - MINOR: ssl: use bit fields to store ssl options instead of one int each
16880 - MINOR: ssl: add 'force-sslv3' and 'force-tlsvXX' statements on bind.
16881 - MINOR: ssl: add 'force-sslv3' and 'force-tlsvXX' statements on server
16882 - MINOR: ssl: add defines LISTEN_DEFAULT_CIPHERS and CONNECT_DEFAULT_CIPHERS.
16883 - BUG/MINOR: ssl: Fix issue on server statements 'no-tls*' and 'no-sslv3'
16884 - MINOR: ssl: move ssl context init for servers from cfgparse.c to ssl_sock.c
16885 - MEDIUM: ssl: reject ssl server keywords in default-server statement
16886 - MINOR: ssl: add statement 'no-tls-tickets' on server side.
16887 - MINOR: ssl: add statements 'verify', 'ca-file' and 'crl-file' on servers.
16888 - DOC: Fix rename of options cafile and crlfile to ca-file and crl-file.
16889 - MINOR: sample: manage binary to string type convertion in stick-table and samples.
16890 - MINOR: acl: add parse and match primitives to use binary type on ACLs
16891 - MINOR: sample: export 'sample_get_trash_chunk(void)'
16892 - MINOR: conf: rename all ssl modules fetches using prefix 'ssl_fc' and 'ssl_c'
16893 - MINOR: ssl: add pattern and ACLs fetches 'ssl_fc_protocol', 'ssl_fc_cipher', 'ssl_fc_use_keysize' and 'ssl_fc_alg_keysize'
16894 - MINOR: ssl: add pattern fetch 'ssl_fc_session_id'
16895 - MINOR: ssl: add pattern and ACLs fetches 'ssl_c_version' and 'ssl_f_version'
16896 - MINOR: ssl: add pattern and ACLs fetches 'ssl_c_s_dn', 'ssl_c_i_dn', 'ssl_f_s_dn' and 'ssl_c_i_dn'
16897 - MINOR: ssl: add pattern and ACLs 'ssl_c_sig_alg' and 'ssl_f_sig_alg'
16898 - MINOR: ssl: add pattern and ACLs fetches 'ssl_c_key_alg' and 'ssl_f_key_alg'
16899 - MINOR: ssl: add pattern and ACLs fetches 'ssl_c_notbefore', 'ssl_c_notafter', 'ssl_f_notbefore' and 'ssl_f_notafter'
16900 - MINOR: ssl: add 'crt' statement on server.
16901 - MINOR: ssl: checks the consistency of a private key with the corresponding certificate
16902 - BUG/MEDIUM: ssl: review polling on reneg.
16903 - BUG/MEDIUM: ssl: Fix some reneg cases not correctly handled.
16904 - BUG/MEDIUM: ssl: Fix sometimes reneg fails if requested by server.
16905 - MINOR: build: allow packagers to specify the ssl cache size
16906 - MINOR: conf: add warning if ssl is not enabled and a certificate is present on bind.
16907 - MINOR: ssl: Add tune.ssl.lifetime statement in global.
16908 - MINOR: compression: Enable compression for IE6 w/SP2, IE7 and IE8
16909 - BUG: http: revert broken optimisation from 82fe75c1a79dac933391501b9d293bce34513755
16910 - DOC: duplicate ssl_sni section
16911 - MEDIUM: HTTP compression (zlib library support)
16912 - CLEANUP: use struct comp_ctx instead of union
16913 - BUILD: remove dependency to zlib.h
16914 - MINOR: compression: memlevel and windowsize
16915 - MEDIUM: use pool for zlib
16916 - MINOR: compression: try init in cfgparse.c
16917 - MINOR: compression: init before deleting headers
16918 - MEDIUM: compression: limit RAM usage
16919 - MINOR: compression: tune.comp.maxlevel
16920 - MINOR: compression: maximum compression rate limit
16921 - MINOR: log-format: check number of arguments in cfgparse.c
16922 - BUG/MEDIUM: compression: no Content-Type header but type in configuration
16923 - BUG/MINOR: compression: deinit zlib only when required
16924 - MEDIUM: compression: don't compress when no data
16925 - MEDIUM: compression: use pool for comp_ctx
16926 - MINOR: compression: rate limit in 'show info'
16927 - MINOR: compression: report zlib memory usage
16928 - BUG/MINOR: compression: dynamic level increase
16929 - DOC: compression: unsupported cases.
16930 - MINOR: compression: CPU usage limit
16931 - MEDIUM: http: add "redirect scheme" to ease HTTP to HTTPS redirection
16932 - BUG/MAJOR: ssl: missing tests in ACL fetch functions
16933 - MINOR: config: add a function to indent error messages
16934 - REORG: split "protocols" files into protocol and listener
16935 - MEDIUM: config: replace ssl_conf by bind_conf
16936 - CLEANUP: listener: remove unused conf->file and conf->line
16937 - MEDIUM: listener: add a minimal framework to register "bind" keyword options
16938 - MEDIUM: config: move the "bind" TCP parameters to proto_tcp
16939 - MEDIUM: move bind SSL parsing to ssl_sock
16940 - MINOR: config: improve error reporting for "bind" lines
16941 - MEDIUM: config: move the common "bind" settings to listener.c
16942 - MEDIUM: config: move all unix-specific bind keywords to proto_uxst.c
16943 - MEDIUM: config: enumerate full list of registered "bind" keywords upon error
16944 - MINOR: listener: add a scope field in the bind keyword lists
16945 - MINOR: config: pass the file and line to config keyword parsers
16946 - MINOR: stats: fill the file and line numbers in the stats frontend
16947 - MINOR: config: set the bind_conf entry on listeners created from a "listen" line.
16948 - MAJOR: listeners: use dual-linked lists to chain listeners with frontends
16949 - REORG: listener: move unix perms from the listener to the bind_conf
16950 - BUG: backend: balance hdr was broken since 1.5-dev11
16951 - MINOR: standard: make memprintf() support a NULL destination
16952 - MINOR: config: make str2listener() use memprintf() to report errors.
16953 - MEDIUM: stats: remove the stats_sock struct from the global struct
16954 - MINOR: ssl: set the listeners' data layer to ssl during parsing
16955 - MEDIUM: stats: make use of the standard "bind" parsers to parse global socket
16956 - DOC: move bind options to their own section
16957 - DOC: stats: refer to "bind" section for "stats socket" settings
16958 - DOC: fix index to reference bind and server options
16959 - BUG: http: do not print garbage on invalid requests in debug mode
16960 - BUG/MINOR: config: check the proper pointer to report unknown protocol
16961 - CLEANUP: connection: offer conn_prepare() to set up a connection
16962 - CLEANUP: config: fix typo inteface => interface
16963 - BUG: stats: fix regression introduced by commit 4348fad1
16964 - MINOR: cli: allow to set frontend maxconn to zero
16965 - BUG/MAJOR: http: chunk parser was broken with buffer changes
16966 - MEDIUM: monitor: simplify handling of monitor-net and mode health
16967 - MINOR: connection: add a pointer to the connection owner
16968 - MEDIUM: connection: make use of the owner instead of container_of
16969 - BUG/MINOR: ssl: report the L4 connection as established when possible
16970 - BUG/MEDIUM: proxy: must not try to stop disabled proxies upon reload
16971 - BUG/MINOR: config: use a copy of the file name in proxy configurations
16972 - BUG/MEDIUM: listener: don't pause protocols that do not support it
16973 - MEDIUM: proxy: add the global frontend to the list of normal proxies
16974 - BUG/MINOR: epoll: correctly disable FD polling in fd_rem()
16975 - MINOR: signal: really ignore signals configured with no handler
16976 - MINOR: buffers: add a few functions to write chars, strings and blocks
16977 - MINOR: raw_sock: always report asynchronous connection errors
16978 - MEDIUM: raw_sock: improve connection error reporting
16979 - REORG: connection: rename the data layer the "transport layer"
16980 - REORG: connection: rename app_cb "data"
16981 - MINOR: connection: provide a generic data layer wakeup callback
16982 - MINOR: connection: split conn_prepare() in two functions
16983 - MINOR: connection: add an init callback to the data_cb struct
16984 - MEDIUM: session: use a specific data_cb for embryonic sessions
16985 - MEDIUM: connection: use a generic data-layer init() callback
16986 - MEDIUM: connection: reorganize connection flags
16987 - MEDIUM: connection: only call the data->wake callback on activity
16988 - MEDIUM: connection: make it possible for data->wake to return an error
16989 - MEDIUM: session: register a data->wake callback to process errors
16990 - MEDIUM: connection: don't call the data->init callback upon error
16991 - MEDIUM: connection: it's not the data layer's role to validate the connection
16992 - MEDIUM: connection: automatically disable polling on error
16993 - REORG: connection: move the PROXY protocol management to connection.c
16994 - MEDIUM: connection: add a new local send-proxy transport callback
16995 - MAJOR: checks: make use of the connection layer to send checks
16996 - REORG: server: move the check-specific parts into a check subsection
16997 - MEDIUM: checks: use real buffers to store requests and responses
16998 - MEDIUM: check: add the ctrl and transport layers in the server check structure
16999 - MAJOR: checks: completely use the connection transport layer
17000 - MEDIUM: checks: add the "check-ssl" server option
17001 - MEDIUM: checks: enable the PROXY protocol with health checks
17002 - CLEANUP: checks: remove minor warnings for assigned but not used variables
17003 - MEDIUM: tcp: enable TCP Fast Open on systems which support it
17004 - BUG: connection: fix regression from commit 9e272bf9
17005 - CLEANUP: cttproxy: remove a warning on undeclared close()
17006 - BUG/MAJOR: ensure that hdr_idx is always reserved when L7 fetches are used
17007 - MEDIUM: listener: add support for linux's accept4() syscall
17008 - MINOR: halog: sort output by cookie code
17009 - BUG/MINOR: halog: -ad/-ac report the correct number of output lines
17010 - BUG/MINOR: halog: fix help message for -ut/-uto
17011 - MINOR: halog: add a parameter to limit output line count
17012 - BUILD: accept4: move the socketcall declaration outside of accept4()
17013 - MINOR: server: add minimal infrastructure to parse keywords
17014 - MINOR: standard: make indent_msg() support empty messages
17015 - MEDIUM: server: check for registered keywords when parsing unknown keywords
17016 - MEDIUM: server: move parsing of keyword "id" to server.c
17017 - BUG/MEDIUM: config: check-send-proxy was ignored if SSL was not builtin
17018 - MEDIUM: ssl: move "server" keyword SSL options parsing to ssl_sock.c
17019 - MEDIUM: log: suffix the frontend's name with '~' when using SSL
17020 - MEDIUM: connection: always unset the transport layer upon close
17021 - BUG/MINOR: session: fix some leftover from debug code
17022 - BUG/MEDIUM: session: enable the conn_session_update() callback
17023 - MEDIUM: connection: add a flag to hold the transport layer
17024 - MEDIUM: log: add a new LW_XPRT flag to pin the transport layer
17025 - MINOR: log: make lf_text use a const char *
17026 - MEDIUM: log: report SSL ciphers and version in logs using logformat %sslc/%sslv
17027 - REORG: http: rename msg->buf to msg->chn since it's a channel
17028 - CLEANUP: http: use 'chn' to name channel variables, not 'buf'
17029 - CLEANUP: channel: use 'chn' instead of 'buf' as local variable names
17030 - CLEANUP: tcp: use 'chn' instead of 'buf' or 'b' for channel pointer names
17031 - CLEANUP: stream_interface: use 'chn' instead of 'b' to name channel pointers
17032 - CLEANUP: acl: use 'chn' instead of 'b' to name channel pointers
17033 - MAJOR: channel: replace the struct buffer with a pointer to a buffer
17034 - OPTIM: channel: reorganize struct members to improve cache efficiency
17035 - CLEANUP: session: remove term_trace which is not used anymore
17036 - OPTIM: session: reorder struct session fields
17037 - OPTIM: connection: pack the struct target
17038 - DOC: document relations between internal entities
17039 - MINOR: ssl: add 'ssl_npn' sample/acl to extract TLS/NPN information
17040 - BUILD: ssl: fix shctx build on older compilers
17041 - MEDIUM: ssl: add support for the "npn" bind keyword
17042 - BUG: ssl: fix ssl_sni ACLs to correctly process regular expressions
17043 - MINOR: chunk: provide string compare functions
17044 - MINOR: sample: accept fetch keywords without parenthesis
17045 - MEDIUM: sample: pass an empty list instead of a null for fetch args
17046 - MINOR: ssl: improve socket behaviour upon handshake abort.
17047 - BUG/MEDIUM: http: set DONTWAIT on data when switching to tunnel mode
17048 - MEDIUM: listener: provide a fallback for accept4() when not supported
17049 - BUG/MAJOR: connection: risk of crash on certain tricky close scenario
17050 - MEDIUM: cli: allow the stats socket to be bound to a specific set of processes
17051 - OPTIM: channel: inline channel_forward's fast path
17052 - OPTIM: http: inline http_parse_chunk_size() and http_skip_chunk_crlf()
17053 - OPTIM: tools: inline hex2i()
17054 - CLEANUP: http: rename HTTP_MSG_DATA_CRLF state
17055 - MINOR: compression: automatically disable compression for older browsers
17056 - MINOR: compression: optimize memLevel to improve byte rate
17057 - BUG/MINOR: http: compression should consider all Accept-Encoding header values
17058 - BUILD: fix coexistence of openssl and zlib
17059 - MINOR: ssl: add pattern and ACLs fetches 'ssl_c_serial' and 'ssl_f_serial'
17060 - BUG/MEDIUM: command-line option -D must have precedence over "debug"
17061 - MINOR: tools: add a clear_addr() function to unset an address
17062 - BUG/MEDIUM: tcp: transparent bind to the source only when address is set
17063 - CLEANUP: remove trashlen
17064 - MAJOR: session: detach the connections from the stream interfaces
17065 - DOC: update document describing relations between internal entities
17066 - BUILD: make it possible to specify ZLIB path
17067 - MINOR: compression: add an offload option to remove the Accept-Encoding header
17068 - BUG: compression: disable auto-close and enable MSG_MORE during transfer
17069 - CLEANUP: completely remove trashlen
17070 - MINOR: chunk: add a function to reset a chunk
17071 - CLEANUP: replace chunk_printf() with chunk_appendf()
17072 - MEDIUM: make the trash be a chunk instead of a char *
17073 - MEDIUM: remove remains of BUFSIZE in HTTP auth and sample conversions
17074 - MEDIUM: stick-table: allocate the table key of size buffer size
17075 - BUG/MINOR: stream_interface: don't loop over ->snd_buf()
17076 - BUG/MINOR: session: ensure that we don't retry connection if some data were sent
17077 - OPTIM: session: don't process the whole session when only timers need a refresh
17078 - BUG/MINOR: session: mark the handshake as complete earlier
17079 - MAJOR: connection: remove the CO_FL_CURR_*_POL flag
17080 - BUG/MAJOR: always clear the CO_FL_WAIT_* flags after updating polling flags
17081 - MAJOR: sepoll: make the poller totally event-driven
17082 - OPTIM: stream_interface: disable reading when CF_READ_DONTWAIT is set
17083 - BUILD: compression: remove a build warning
17084 - MEDIUM: fd: don't unset fdtab[].updated upon delete
17085 - REORG: fd: move the speculative I/O management from ev_sepoll
17086 - REORG: fd: move the fd state management from ev_sepoll
17087 - REORG: fd: centralize the processing of speculative events
17088 - BUG: raw_sock: also consider ENOTCONN in addition to EAGAIN
17089 - BUILD: stream_interface: remove si_fd() and its references
17090 - BUILD: compression: enable build in BSD and OSX Makefiles
17091 - MAJOR: ev_select: make the poller support speculative events
17092 - MAJOR: ev_poll: make the poller support speculative events
17093 - MAJOR: ev_kqueue: make the poller support speculative events
17094 - MAJOR: polling: replace epoll with sepoll and remove sepoll
17095 - MAJOR: polling: remove unused callbacks from the poller struct
17096 - MEDIUM: http: refrain from sending "Connection: close" when Upgrade is present
17097 - CLEANUP: channel: remove any reference of the hijackers
17098 - CLEANUP: stream_interface: remove the external task type target
17099 - MAJOR: connection: replace struct target with a pointer to an enum
17100 - BUG: connection: fix typo in previous commit
17101 - BUG: polling: don't skip polled events in the spec list
17102 - MINOR: splice: disable it when the system returns EBADF
17103 - MINOR: build: allow packagers to specify the default maxzlibmem
17104 - BUG: halog: fix broken output limitation
17105 - BUG: proxy: fix server name lookup in get_backend_server()
17106 - BUG: compression: do not always increment the round counter on allocation failure
17107 - BUG/MEDIUM: compression: release the zlib pools between keep-alive requests
17108 - MINOR: global: don't prevent nbproc from being redefined
17109 - MINOR: config: support process ranges for "bind-process"
17110 - MEDIUM: global: add support for CPU binding on Linux ("cpu-map")
17111 - MINOR: ssl: rename and document the tune.ssl.cachesize option
17112 - DOC: update the PROXY protocol spec to support v2
17113 - MINOR: standard: add a simple popcount function
17114 - MEDIUM: adjust the maxaccept per listener depending on the number of processes
17115 - BUG: compression: properly disable compression when content-type does not match
17116 - MINOR: cli: report connection status in "show sess xxx"
17117 - BUG/MAJOR: stream_interface: certain workloads could cause get stuck
17118 - BUILD: cli: fix build when SSL is enabled
17119 - MINOR: cli: report the fd state in "show sess xxx"
17120 - MINOR: cli: report an error message on missing argument to compression rate
17121 - MINOR: http: add some debugging functions to pretty-print msg state names
17122 - BUG/MAJOR: stream_interface: read0 not always handled since dev12
17123 - DOC: documentation on http header capture is wrong
17124 - MINOR: http: allow the cookie capture size to be changed
17125 - DOC: http header capture has not been limited in size for a long time
17126 - DOC: update readme with build methods for BSD
17127 - BUILD: silence a warning on Solaris about usage of isdigit()
17128 - MINOR: stats: report HTTP compression stats per frontend and per backend
17129 - MINOR: log: add '%Tl' to log-format
17130 - MINOR: samples: update the url_param fetch to match parameters in the path
17131
Willy Tarreau16216822012-09-10 09:46:55 +0200171322012/09/10 : 1.5-dev12
17133 - CONTRIB: halog: sort URLs by avg bytes_read or total bytes_read
17134 - MEDIUM: ssl: add support for prefer-server-ciphers option
17135 - MINOR: IPv6 support for transparent proxy
17136 - MINOR: protocol: add SSL context to listeners if USE_OPENSSL is defined
17137 - MINOR: server: add SSL context to servers if USE_OPENSSL is defined
17138 - MEDIUM: connection: add a new handshake flag for SSL (CO_FL_SSL_WAIT_HS).
17139 - MEDIUM: ssl: add new files ssl_sock.[ch] to provide the SSL data layer
17140 - MEDIUM: config: add the 'ssl' keyword on 'bind' lines
17141 - MEDIUM: config: add support for the 'ssl' option on 'server' lines
17142 - MEDIUM: ssl: protect against client-initiated renegociation
17143 - BUILD: add optional support for SSL via the USE_OPENSSL flag
17144 - MEDIUM: ssl: add shared memory session cache implementation.
17145 - MEDIUM: ssl: replace OpenSSL's session cache with the shared cache
17146 - MINOR: ssl add global setting tune.sslcachesize to set SSL session cache size.
17147 - MEDIUM: ssl: add support for SNI and wildcard certificates
17148 - DOC: Typos cleanup
17149 - DOC: fix name for "option independant-streams"
17150 - DOC: specify the default value for maxconn in the context of a proxy
17151 - BUG/MINOR: to_log erased with unique-id-format
17152 - LICENSE: add licence exception for OpenSSL
17153 - BUG/MAJOR: cookie prefix doesn't support cookie-less servers
17154 - BUILD: add an AIX 5.2 (and later) target.
17155 - MEDIUM: fd/si: move peeraddr from struct fdinfo to struct connection
17156 - MINOR: halog: use the more recent dual-mode fgets2 implementation
17157 - BUG/MEDIUM: ebtree: ebmb_insert() must not call cmp_bits on full-length matches
17158 - CLEANUP: halog: make clean should also remove .o files
17159 - OPTIM: halog: make use of memchr() on platforms which provide a fast one
17160 - OPTIM: halog: improve cold-cache behaviour when loading a file
17161 - BUG/MINOR: ACL implicit arguments must be created with unresolved flag
17162 - MINOR: replace acl_fetch_{path,url}* with smp_fetch_*
17163 - MEDIUM: pattern: add the "base" sample fetch method
17164 - OPTIM: i386: make use of kernel-mode-linux when available
17165 - BUG/MINOR: tarpit: fix condition to return the HTTP 500 message
17166 - BUG/MINOR: polling: some events were not set in various pollers
17167 - MINOR: http: add the urlp_val ACL match
17168 - BUG: stktable: tcp_src_to_stktable_key() must return NULL on invalid families
17169 - MINOR: stats/cli: add plans to support more stick-table actions
17170 - MEDIUM: stats/cli: add support for "set table key" to enter values
17171 - REORG/MEDIUM: fd: remove FD_STCLOSE from struct fdtab
17172 - REORG/MEDIUM: fd: remove checks for FD_STERROR in ev_sepoll
17173 - REORG/MEDIUM: fd: get rid of FD_STLISTEN
17174 - REORG/MINOR: connection: move declaration to its own include file
17175 - REORG/MINOR: checks: put a struct connection into the server
17176 - MINOR: connection: add flags to the connection struct
17177 - MAJOR: get rid of fdtab[].state and use connection->flags instead
17178 - MINOR: fd: add a new I/O handler to fdtab
17179 - MEDIUM: polling: prepare to call the iocb() function when defined.
17180 - MEDIUM: checks: make use of fdtab->iocb instead of cb[]
17181 - MEDIUM: protocols: use the generic I/O callback for accept callbacks
17182 - MINOR: connection: add a handler for fd-based connections
17183 - MAJOR: connection: replace direct I/O callbacks with the connection callback
17184 - MINOR: fd: make fdtab->owner a connection and not a stream_interface anymore
17185 - MEDIUM: connection: remove the FD_POLL_* flags only once
17186 - MEDIUM: connection: extract the send_proxy callback from proto_tcp
17187 - MAJOR: tcp: remove the specific I/O callbacks for TCP connection probes
17188 - CLEANUP: remove the now unused fdtab direct I/O callbacks
17189 - MAJOR: remove the stream interface and task management code from sock_*
17190 - MEDIUM: stream_interface: pass connection instead of fd in sock_ops
17191 - MEDIUM: stream_interface: centralize the SI_FL_ERR management
17192 - MAJOR: connection: add a new CO_FL_CONNECTED flag
17193 - MINOR: rearrange tcp_connect_probe() and fix wrong return codes
17194 - MAJOR: connection: call data layer handshakes from the handler
17195 - MEDIUM: fd: remove the EV_FD_COND_* primitives
17196 - MINOR: sock_raw: move calls to si_data_close upper
17197 - REORG: connection: replace si_data_close() with conn_data_close()
17198 - MEDIUM: sock_raw: introduce a read0 callback that is different from shutr
17199 - MAJOR: stream_int: use a common stream_int_shut*() functions regardless of the data layer
17200 - MAJOR: fd: replace all EV_FD_* macros with new fd_*_* inline calls
17201 - MEDIUM: fd: add fd_poll_{recv,send} for use when explicit polling is required
17202 - MEDIUM: connection: add definitions for dual polling mechanisms
17203 - MEDIUM: connection: make use of the new polling functions
17204 - MAJOR: make use of conn_{data|sock}_{poll|stop|want}* in connection handlers
17205 - MEDIUM: checks: don't use FD_WAIT_* anymore
17206 - MINOR: fd: get rid of FD_WAIT_*
17207 - MEDIUM: stream_interface: offer a generic function for connection updates
17208 - MEDIUM: stream-interface: offer a generic chk_rcv function for connections
17209 - MEDIUM: stream-interface: add a snd_buf() callback to sock_ops
17210 - MEDIUM: stream-interface: provide a generic stream_int_chk_snd_conn() function
17211 - MEDIUM: stream-interface: provide a generic si_conn_send_cb callback
17212 - MEDIUM: stream-interface: provide a generic stream_sock_read0() function
17213 - REORG/MAJOR: use "struct channel" instead of "struct buffer"
17214 - REORG/MAJOR: extract "struct buffer" from "struct channel"
17215 - MINOR: connection: provide conn_{data|sock}_{read0|shutw} functions
17216 - REORG: sock_raw: rename the files raw_sock*
17217 - MAJOR: raw_sock: extract raw_sock_to_buf() from raw_sock_read()
17218 - MAJOR: raw_sock: temporarily disable splicing
17219 - MINOR: stream-interface: add an rcv_buf callback to sock_ops
17220 - REORG: stream-interface: move sock_raw_read() to si_conn_recv_cb()
17221 - MAJOR: connection: split the send call into connection and stream interface
17222 - MAJOR: stream-interface: restore splicing mechanism
17223 - MAJOR: stream-interface: make conn_notify_si() more robust
17224 - MEDIUM: proxy-proto: don't use buffer flags in conn_si_send_proxy()
17225 - MAJOR: stream-interface: don't commit polling changes in every callback
17226 - MAJOR: stream-interface: fix splice not to call chk_snd by itself
17227 - MEDIUM: stream-interface: don't remove WAIT_DATA when a handshake is in progress
17228 - CLEANUP: connection: split sock_ops into data_ops, app_cp and si_ops
17229 - REORG: buffers: split buffers into chunk,buffer,channel
17230 - MAJOR: channel: remove the BF_OUT_EMPTY flag
17231 - REORG: buffer: move buffer_flush, b_adv and b_rew to buffer.h
17232 - MINOR: channel: rename bi_full to channel_full as it checks the whole channel
17233 - MINOR: buffer: provide a new buffer_full() function
17234 - MAJOR: channel: stop relying on BF_FULL to take action
17235 - MAJOR: channel: remove the BF_FULL flag
17236 - REORG: channel: move buffer_{replace,insert_line}* to buffer.{c,h}
17237 - CLEANUP: channel: usr CF_/CHN_ prefixes instead of BF_/BUF_
17238 - CLEANUP: channel: use "channel" instead of "buffer" in function names
17239 - REORG: connection: move the target pointer from si to connection
17240 - MAJOR: connection: move the addr field from the stream_interface
17241 - MEDIUM: stream_interface: remove CAP_SPLTCP/CAP_SPLICE flags
17242 - MEDIUM: proto_tcp: remove any dependence on stream_interface
17243 - MINOR: tcp: replace tcp_src_to_stktable_key with addr_to_stktable_key
17244 - MEDIUM: connection: add an ->init function to data layer
17245 - MAJOR: session: introduce embryonic sessions
17246 - MAJOR: connection: make the PROXY decoder a handshake handler
17247 - CLEANUP: frontend: remove the old proxy protocol decoder
17248 - MAJOR: connection: rearrange the polling flags.
17249 - MEDIUM: connection: only call tcp_connect_probe when nothing was attempted yet
17250 - MEDIUM: connection: complete the polling cleanups
17251 - MEDIUM: connection: avoid calling handshakes when polling is required
17252 - MAJOR: stream_interface: continue to update data polling flags during handshakes
17253 - CLEANUP: fd: remove fdtab->flags
17254 - CLEANUP: fdtab: flatten the struct and merge the spec struct with the rest
17255 - CLEANUP: includes: fix includes for a number of users of fd.h
17256 - MINOR: ssl: disable TCP quick-ack by default on SSL listeners
17257 - MEDIUM: config: add a "ciphers" keyword to set SSL cipher suites
17258 - MEDIUM: config: add "nosslv3" and "notlsv1" on bind and server lines
17259 - BUG: ssl: mark the connection as waiting for an SSL connection during the handshake
17260 - BUILD: http: rename error_message http_error_message to fix conflicts on RHEL
17261 - BUILD: ssl: fix shctx build on RHEL with futex
17262 - BUILD: include sys/socket.h to fix build failure on FreeBSD
17263 - BUILD: fix build error without SSL (ssl_cert)
17264 - BUILD: ssl: use MAP_ANON instead of MAP_ANONYMOUS
17265 - BUG/MEDIUM: workaround an eglibc bug which truncates the pidfiles when nbproc > 1
17266 - MEDIUM: config: support per-listener backlog and maxconn
17267 - MINOR: session: do not send an HTTP/500 error on SSL sockets
17268 - MEDIUM: config: implement maxsslconn in the global section
17269 - BUG: tcp: close socket fd upon connect error
17270 - MEDIUM: connection: improve error handling around the data layer
17271 - MINOR: config: make the tasks "nice" value configurable on "bind" lines.
17272 - BUILD: shut a gcc warning introduced by commit 269ab31
17273 - MEDIUM: config: centralize handling of SSL config per bind line
17274 - BUILD: makefile: report USE_OPENSSL status in build options
17275 - BUILD: report openssl build settings in haproxy -vv
17276 - MEDIUM: ssl: add sample fetches for is_ssl, ssl_has_sni, ssl_sni_*
17277 - DOC: add a special acknowledgement for the stud project
17278 - DOC: add missing SSL options for servers and listeners
17279 - BUILD: automatically add -lcrypto for SSL
17280 - DOC: add some info about openssl build in the README
17281
Willy Tarreau02c7c142012-06-04 00:43:45 +0200172822012/06/04 : 1.5-dev11
17283 - BUG/MEDIUM: option forwardfor if-none doesn't work with some configurations
17284 - BUG/MAJOR: trash must always be the size of a buffer
17285 - DOC: fix minor regex example issue and improve doc on stats
17286 - MINOR: stream_interface: add a pointer to the listener for TARG_TYPE_CLIENT
17287 - MEDIUM: protocol: add a pointer to struct sock_ops to the listener struct
17288 - MINOR: checks: add on-marked-up option
17289 - MINOR: balance uri: added 'whole' parameter to include query string in hash calculation
17290 - MEDIUM: stream_interface: remove the si->init
17291 - MINOR: buffers: add a rewind function
17292 - BUG/MAJOR: fix regression on content-based hashing and http-send-name-header
17293 - MAJOR: http: stop using msg->sol outside the parsers
17294 - CLEANUP: http: make it more obvious that msg->som is always null outside of chunks
17295 - MEDIUM: http: get rid of msg->som which is not used anymore
17296 - MEDIUM: http: msg->sov and msg->sol will never wrap
17297 - BUG/MAJOR: checks: don't call set_server_status_* when no LB algo is set
17298 - BUG/MINOR: stop connect timeout when connect succeeds
17299 - REORG: move the send-proxy code to tcp_connect_write()
17300 - REORG/MINOR: session: detect the TCP monitor checks at the protocol accept
17301 - MINOR: stream_interface: introduce a new "struct connection" type
17302 - REORG/MINOR: stream_interface: move si->fd to struct connection
17303 - REORG/MEDIUM: stream_interface: move applet->state and private to connection
17304 - MINOR: stream_interface: add a data channel close function
17305 - MEDIUM: stream_interface: call si_data_close() before releasing the si
17306 - MINOR: peers: use the socket layer operations from the peer instead of sock_raw
17307 - BUG/MINOR: checks: expire on timeout.check if smaller than timeout.connect
17308 - MINOR: add a new function call tracer for debugging purposes
17309 - BUG/MINOR: perform_http_redirect also needs to rewind the buffer
17310 - BUG/MAJOR: b_rew() must pass a signed offset to b_ptr()
17311 - BUG/MEDIUM: register peer sync handler in the proper order
17312 - BUG/MEDIUM: buffers: fix bi_putchr() to correctly advance the pointer
17313 - BUG/MINOR: fix option httplog validation with TCP frontends
17314 - BUG/MINOR: log: don't report logformat errors in backends
17315 - REORG/MINOR: use dedicated proxy flags for the cookie handling
17316 - BUG/MINOR: config: do not report twice the incompatibility between cookie and non-http
17317 - MINOR: http: add support for "httponly" and "secure" cookie attributes
17318 - BUG/MEDIUM: ensure that unresolved arguments are freed exactly once
17319 - BUG/MINOR: commit 196729ef used wrong condition resulting in freeing constants
17320 - MEDIUM: stats: add support for soft stop/soft start in the admin interface
17321 - MEDIUM: stats: add the ability to kill sessions from the admin interface
17322 - BUILD: add support for linux kernels >= 2.6.28
17323
Willy Tarreauffb89472012-05-14 07:26:56 +0200173242012/05/14 : 1.5-dev10
17325 - BUG/MINOR: stats admin: "Unexpected result" was displayed unconditionally
17326 - BUG/MAJOR: acl: http_auth_group() must not accept any user from the userlist
17327 - CLEANUP: auth: make the code build again with DEBUG_AUTH
17328 - BUG/MEDIUM: config: don't crash at config load time on invalid userlist names
17329 - REORG: use the name sock_raw instead of stream_sock
17330 - MINOR: stream_interface: add a client target : TARG_TYPE_CLIENT
17331 - BUG/MEDIUM: stream_interface: restore get_src/get_dst
17332 - CLEANUP: sock_raw: remove last references to stream_sock
17333 - CLEANUP: stream_interface: stop exporting socket layer functions
17334 - MINOR: stream_interface: add an init callback to sock_ops
17335 - MEDIUM: stream_interface: derive the socket operations from the target
17336 - MAJOR: fd: remove the need for the socket layer to recheck the connection
17337 - MINOR: session: call the socket layer init function when a session establishes
17338 - MEDIUM: session: add support for tunnel timeouts
17339 - MINOR: standard: add a new debug macro : fddebug()
17340 - CLEANUP: fd: remove unused cb->b pointers in the struct fdtab
17341 - OPTIM: proto_http: don't enable quick-ack on empty buffers
17342 - OPTIM/MAJOR: ev_sepoll: process spec events after polled events
17343 - OPTIM/MEDIUM: stream_interface: add a new SI_FL_NOHALF flag
17344
Willy Tarreaua0564f32012-05-08 21:56:27 +0200173452012/05/08 : 1.5-dev9
17346 - MINOR: Add release callback to si_applet
17347 - CLEANUP: Fix some minor typos
17348 - MINOR: Add TO/FROM_SET flags to struct stream_interface
17349 - CLEANUP: Fix some minor whitespace issues
17350 - MINOR: stats admin: allow unordered parameters in POST requests
17351 - CLEANUP: fix typo in findserver() log message
17352 - MINOR: stats admin: use the backend id instead of its name in the form
17353 - MINOR: stats admin: reduce memcmp()/strcmp() calls on status codes
17354 - DOC: cleanup indentation, alignment, columns and chapters
17355 - DOC: fix some keywords arguments documentation
17356 - MINOR: cli: display the 4 IP addresses and ports on "show sess XXX"
17357 - BUG/MAJOR: log: possible segfault with logformat
17358 - MEDIUM: log: split of log_format generation
17359 - MEDIUM: log: New format-log flags: %Fi %Fp %Si %Sp %Ts %rt %H %pid
17360 - MEDIUM: log: Unique ID
17361 - MINOR: log: log-format: usable without httplog and tcplog
17362 - BUG/MEDIUM: balance source did not properly hash IPv6 addresses
17363 - MINOR: contrib/iprange: add a network IP range to mask converter
17364 - MEDIUM: session: implement the "use-server" directive
17365 - MEDIUM: log: add a new cookie flag 'U' to report situations where cookie is not used
17366 - MEDIUM: http: make extract_cookie_value() iterate over cookie values
17367 - MEDIUM: http: add cookie and scookie ACLs
17368 - CLEANUP: lb_first: add reference to a paper describing the original idea
17369 - MEDIUM: stream_sock: add a get_src and get_dst callback and remove SN_FRT_ADDR_SET
17370 - BUG/MINOR: acl: req_ssl_sni would randomly fail if a session ID is present
17371 - BUILD: http: make extract_cookie_value() return an int not size_t
17372 - BUILD: http: stop gcc-4.1.2 from complaining about possibly uninitialized values
17373 - CLEANUP: http: message parser must ignore HTTP_MSG_ERROR
17374 - MINOR: standard: add a memprintf() function to build formatted error messages
17375 - CLEANUP: remove a few warning about unchecked return values in debug code
17376 - MEDIUM: move message-related flags from transaction to message
17377 - DOC: add a diagram to explain how circular buffers work
17378 - MAJOR: buffer rework: replace ->send_max with ->o
17379 - MAJOR: buffer: replace buf->l with buf->{o+i}
17380 - MINOR: buffers: provide simple pointer normalization functions
17381 - MINOR: buffers: remove unused function buffer_contig_data()
17382 - MAJOR: buffers: replace buf->w with buf->p - buf->o
17383 - MAJOR: buffers: replace buf->r with buf->p + buf->i
17384 - MAJOR: http: move buffer->lr to http_msg->next
17385 - MAJOR: http: change msg->{som,col,sov,eoh} to be relative to buffer origin
17386 - CLEANUP: http: remove unused http_msg->col
17387 - MAJOR: http: turn http_msg->eol to a buffer-relative offset
17388 - MEDIUM: http: add a pointer to the buffer in http_msg
17389 - MAJOR: http: make http_msg->sol relative to buffer's origin
17390 - MEDIUM: http: http_send_name_header: remove references to msg and buffer
17391 - MEDIUM: http: remove buffer arg in a few header manipulation functions
17392 - MEDIUM: http: remove buffer arg in http_capture_bad_message
17393 - MEDIUM: http: remove buffer arg in http_msg_analyzer
17394 - MEDIUM: http: remove buffer arg in http_upgrade_v09_to_v10
17395 - MEDIUM: http: remove buffer arg in http_buffer_heavy_realign
17396 - MEDIUM: http: remove buffer arg in chunk parsing functions
17397 - MINOR: http: remove useless wrapping checks in http_msg_analyzer
17398 - MEDIUM: buffers: fix unsafe use of buffer_ignore at some places
17399 - MEDIUM: buffers: add new pointer wrappers and get rid of almost all buffer_wrap_add calls
17400 - MEDIUM: buffers: implement b_adv() to advance a buffer's pointer
17401 - MEDIUM: buffers: rename a number of buffer management functions
17402 - MEDIUM: http: add a prefetch function for ACL pattern fetch
17403 - MEDIUM: http: make all ACL fetch function use acl_prefetch_http()
17404 - BUG/MINOR: http_auth: ACLs are volatile, not permanent
17405 - MEDIUM: http/acl: merge all request and response ACL fetches of headers and cookies
17406 - MEDIUM: http/acl: make acl_fetch_hdr_{ip,val} rely on acl_fetch_hdr()
17407 - MEDIUM: add a new typed argument list parsing framework
17408 - MAJOR: acl: make use of the new argument parsing framework
17409 - MAJOR: acl: store the ACL argument types in the ACL keyword declaration
17410 - MEDIUM: acl: acl_find_target() now resolves arguments based on their types
17411 - MAJOR: acl: make acl_find_targets also resolve proxy names at config time
17412 - MAJOR: acl: ensure that implicit table and proxies are valid
17413 - MEDIUM: acl: remove unused tests for missing args when args are mandatory
17414 - MEDIUM: pattern: replace type pattern_arg with type arg
17415 - MEDIUM: pattern: get rid of arg_i in all functions making use of arguments
17416 - MEDIUM: pattern: use the standard arg parser
17417 - MEDIUM: pattern: add an argument validation callback to pattern descriptors
17418 - MEDIUM: pattern: report the precise argument parsing error when known.
17419 - MEDIUM: acl: remove the ACL_TEST_F_NULL_MATCH flag
17420 - MINOR: pattern: add a new 'sample' type to store fetched data
17421 - MEDIUM: pattern: add new sample types to replace pattern types
17422 - MAJOR: acl: make use of the new sample struct and get rid of acl_test
17423 - MEDIUM: pattern/acl: get rid of temp_pattern in ACLs
17424 - MEDIUM: acl: get rid of the SET_RES flags
17425 - MEDIUM: get rid of SMP_F_READ_ONLY and SMP_F_MUST_FREE
17426 - MINOR: pattern: replace struct pattern with struct sample
17427 - MEDIUM: pattern: integrate pattern_data into sample and use sample everywhere
17428 - MEDIUM: pattern: retrieve the sample type in the sample, not in the keyword description
17429 - MEDIUM: acl/pattern: switch rdp_cookie functions stack up-down
17430 - MEDIUM: acl: replace acl_expr with args in acl fetch_* functions
17431 - MINOR: tcp: replace acl_fetch_rdp_cookie with smp_fetch_rdp_cookie
17432 - MEDIUM: acl/pattern: use the same direction scheme
17433 - MEDIUM: acl/pattern: start merging common sample fetch functions
17434 - MEDIUM: pattern: ensure that sample types always cast into other types.
17435 - MEDIUM: acl/pattern: factor out the src/dst address fetches
17436 - MEDIUM: acl: implement payload and payload_lv
17437 - CLEANUP: pattern: ensure that payload and payload_lv always stay in the buffer
17438 - MINOR: stick_table: centralize the handling of empty keys
17439 - MINOR: pattern: centralize handling of unstable data in pattern_process()
17440 - MEDIUM: pattern: use smp_fetch_rdp_cookie instead of the pattern specific version
17441 - MINOR: acl: set SMP_OPT_ITERATE on fetch functions
17442 - MINOR: acl: add a val_args field to keywords
17443 - MINOR: proto_tcp: validate arguments of payload and payload_lv ACLs
17444 - MEDIUM: http: merge acl and pattern header fetch functions
17445 - MEDIUM: http: merge ACL and pattern cookie fetches into a single one
17446 - MEDIUM: acl: report parsing errors to the caller
17447 - MINOR: arg: improve error reporting on invalid arguments
17448 - MINOR: acl: report errors encountered when loading patterns from files
17449 - MEDIUM: acl: extend the pattern parsers to report meaningful errors
17450 - REORG: use the name "sample" instead of "pattern" to designate extracted data
17451 - REORG: rename "pattern" files
17452 - MINOR: acl: add types to ACL patterns
17453 - MINOR: standard: add an IPv6 parsing function (str62net)
17454 - MEDIUM: acl: support IPv6 address matching
17455 - REORG: stream_interface: create a struct sock_ops to hold socket operations
17456 - REORG/MEDIUM: move protocol->{read,write} to sock_ops
17457 - REORG/MEDIUM: stream_interface: initialize socket ops from descriptors
17458 - REORG/MEDIUM: replace stream interface protocol functions by a proto pointer
17459 - REORG/MEDIUM: move the default accept function from sockstream to protocols.c
17460 - MEDIUM: proto_tcp: remove src6 and dst6 pattern fetch methods
17461 - BUG/MINOR: http: error snapshots are wrong if buffer wraps
17462 - BUG/MINOR: http: ensure that msg->err_pos is always relative to buf->p
17463 - MEDIUM: http: improve error capture reports
17464 - MINOR: acl: add the cook_val() match to match a cookie against an integer
17465 - BUG/MEDIUM: send_proxy: fix initialisation of send_proxy_ofs
17466 - MEDIUM: memory: add the ability to poison memory at run time
17467 - BUG/MEDIUM: log: ensure that unique_id is properly initialized
17468 - MINOR: cfgparse: use a common errmsg pointer for all parsers
17469 - MEDIUM: cfgparse: make backend_parse_balance() use memprintf to report errors
17470 - MEDIUM: cfgparse: use the new error reporting framework for remaining cfg_keywords
17471 - MINOR: http: replace http_message_realign() with buffer_slow_realign()
17472
Willy Tarreau9eeb57b2012-03-26 06:15:29 +0200174732012/03/26 : 1.5-dev8
17474 - MINOR: patch for minor typo (ressources/resources)
17475 - MEDIUM: http: add support for sending the server's name in the outgoing request
17476 - DOC: mention that default checks are TCP connections
17477 - BUG/MINOR: fix options forwardfor if-none when an alternative header name is specified
17478 - CLEANUP: Make check_statuses, analyze_statuses and process_chk static
17479 - CLEANUP: Fix HCHK spelling errors
17480 - BUG/MINOR: fix typo in processing of http-send-name-header
17481 - MEDIUM: log: Use linked lists for loggers
17482 - BUILD: fix declaration inside a scope block
17483 - REORG: log: split send_log function
17484 - MINOR: config: Parse the string of the log-format config keyword
17485 - MINOR: add ultoa, ulltoa, ltoa, lltoa implementations
17486 - MINOR: Date and time fonctions that don't use snprintf
17487 - MEDIUM: log: make http_sess_log use log_format
17488 - DOC: log-format documentation
17489 - MEDIUM: log: use log_format for mode tcplog
17490 - MEDIUM: log-format: backend source address %Bi %Bp
17491 - BUG/MINOR: log-format: fix %o flag
17492 - BUG/MEDIUM: bad length in log_format and __send_log
17493 - MINOR: logformat %st is signed
17494 - BUILD/MINOR: fix the source URL in the spec file
17495 - DOC: acl is http_first_req, not http_req_first
17496 - BUG/MEDIUM: don't trim last spaces from headers consisting only of spaces
17497 - MINOR: acl: add new matches for header/path/url length
17498 - BUILD: halog: make halog build on solaris
17499 - BUG/MINOR: don't use a wrong port when connecting to a server with mapped ports
17500 - MINOR: remove the client/server side distinction in SI addresses
17501 - MINOR: halog: add support for matching queued requests
17502 - DOC: indicate that cookie "prefix" and "indirect" should not be mixed
17503 - OPTIM/MINOR: move struct sockaddr_storage to the tail of structs
17504 - OPTIM/MINOR: make it possible to change pipe size (tune.pipesize)
17505 - BUILD/MINOR: silent a build warning in src/pipe.c (fcntl)
17506 - OPTIM/MINOR: move the hdr_idx pools out of the proxy struct
17507 - MEDIUM: tune.http.maxhdr makes it possible to configure the maximum number of HTTP headers
17508 - BUG/MINOR: fix a segfault when parsing a config with undeclared peers
17509 - CLEANUP: rename possibly confusing struct field "tracked"
17510 - BUG/MEDIUM: checks: fix slowstart behaviour when server tracking is in use
17511 - MINOR: config: tolerate server "cookie" setting in non-HTTP mode
17512 - MEDIUM: buffers: add some new primitives and rework existing ones
17513 - BUG: buffers: don't return a negative value on buffer_total_space_res()
17514 - MINOR: buffers: make buffer_pointer() support negative pointers too
17515 - CLEANUP: kill buffer_replace() and use an inline instead
17516 - BUG: tcp: option nolinger does not work on backends
17517 - CLEANUP: ebtree: remove a few annoying signedness warnings
17518 - CLEANUP: ebtree: clarify licence and update to 6.0.6
17519 - CLEANUP: ebtree: remove 4-year old harmless typo in duplicates insertion code
17520 - CLEANUP: ebtree: remove another typo, a wrong initialization in insertion code
17521 - BUG: ebtree: ebst_lookup() could return the wrong entry
17522 - OPTIM: stream_sock: reduce the amount of in-flight spliced data
17523 - OPTIM: stream_sock: save a failed recv syscall when splice returns EAGAIN
17524 - MINOR: acl: add support for TLS server name matching using SNI
17525 - BUG: http: re-enable TCP quick-ack upon incomplete HTTP requests
17526 - BUG: proto_tcp: don't try to bind to a foreign address if sin_family is unknown
17527 - MINOR: pattern: export the global temporary pattern
17528 - CLEANUP: patterns: get rid of pattern_data_setstring()
17529 - MEDIUM: acl: use temp_pattern to store fetched information in the "method" match
17530 - MINOR: acl: include pattern.h to make pattern migration more transparent
17531 - MEDIUM: pattern: change the pattern data integer from unsigned to signed
17532 - MEDIUM: acl: use temp_pattern to store any integer-type information
17533 - MEDIUM: acl: use temp_pattern to store any address-type information
17534 - CLEANUP: acl: integer part of acl_test is not used anymore
17535 - MEDIUM: acl: use temp_pattern to store any string-type information
17536 - CLEANUP: acl: remove last data fields from the acl_test struct
17537 - MEDIUM: http: replace get_ip_from_hdr2() with http_get_hdr()
17538 - MEDIUM: patterns: the hdr() pattern is now of type string
17539 - DOC: add minimal documentation on how ACLs work internally
17540 - DOC: add a coding-style file
17541 - OPTIM: halog: keep a fast path for the lines-count only
17542 - CLEANUP: silence a warning when building on sparc
17543 - BUG: http: tighten the list of allowed characters in a URI
17544 - MEDIUM: http: block non-ASCII characters in URIs by default
17545 - DOC: add some documentation from RFC3986 about URI format
17546 - BUG/MINOR: cli: correctly remove the whole table on "clear table"
17547 - BUG/MEDIUM: correctly disable servers tracking another disabled servers.
17548 - BUG/MEDIUM: zero-weight servers must not dequeue requests from the backend
17549 - MINOR: halog: add some help on the command line
17550 - BUILD: fix build error on FreeBSD
17551 - BUG: fix double free in peers config error path
17552 - MEDIUM: improve config check return codes
17553 - BUILD: make it possible to look for pcre in the default system paths
17554 - MINOR: config: emit a warning when 'default_backend' masks servers
17555 - MINOR: backend: rework the LC definition to support other connection-based algos
17556 - MEDIUM: backend: add the 'first' balancing algorithm
17557 - BUG: fix httplog trailing LF
17558 - MEDIUM: increase chunk-size limit to 2GB-1
17559 - BUG: queue: fix dequeueing sequence on HTTP keep-alive sessions
17560 - BUG: http: disable TCP delayed ACKs when forwarding content-length data
17561 - BUG: checks: fix server maintenance exit sequence
17562 - BUG/MINOR: stream_sock: don't remove BF_EXPECT_MORE and BF_SEND_DONTWAIT on partial writes
17563 - DOC: enumerate valid status codes for "observe layer7"
17564 - MINOR: buffer: switch a number of buffer args to const
17565 - CLEANUP: silence signedness warning in acl.c
17566 - BUG: stream_sock: si->release was not called upon shutw()
17567 - MINOR: log: use "%ts" to log term status only and "%tsc" to log with cookie
17568 - BUG/CRITICAL: log: fix risk of crash in development snapshot
17569 - BUG/MAJOR: possible crash when using capture headers on TCP frontends
17570 - MINOR: config: disable header captures in TCP mode and complain
17571
Willy Tarreau60612eb2011-09-10 23:43:11 +0200175722011/09/10 : 1.5-dev7
17573 - [BUG] fix binary stick-tables
17574 - [MINOR] http: *_dom matching header functions now also split on ":"
17575 - [BUG] checks: fix support of Mysqld >= 5.5 for mysql-check
17576 - [MINOR] acl: add srv_conn acl to count connections on a specific backend server
17577 - [MINOR] check: add redis check support
17578 - [DOC] small fixes to clearly distinguish between keyword and variables
17579 - [MINOR] halog: add support for termination code matching (-tcn/-TCN)
17580 - [DOC] Minor spelling fixes and grammatical enhancements
17581 - [CLEANUP] dumpstats: make symbols static where possible
17582 - [MINOR] Break out dumping table
17583 - [MINOR] Break out processing of clear table
17584 - [MINOR] Allow listing of stick table by key
17585 - [MINOR] Break out all stick table socat command parsing
17586 - [MINOR] More flexible clearing of stick table
17587 - [MINOR] Allow showing and clearing by key of ipv6 stick tables
17588 - [MINOR] Allow showing and clearing by key of integer stick tables
17589 - [MINOR] Allow showing and clearing by key of string stick tables
17590 - [CLEANUP] Remove assigned but unused variables
17591 - [CLEANUP] peers.h: fix declarations
17592 - [CLEANUP] session.c: Make functions static where possible
17593 - [MINOR] Add active connection list to server
17594 - [MINOR] Allow shutdown of sessions when a server becomes unavailable
17595 - [MINOR] Add down termination condition
17596 - [MINOR] Make appsess{,ion}_refresh static
17597 - [MINOR] Add rdp_cookie pattern fetch function
17598 - [CLEANUP] Remove unnecessary casts
17599 - [MINOR] Add non-stick server option
17600 - [MINOR] Consistently use error in tcp_parse_tcp_req()
17601 - [MINOR] Consistently free expr on error in cfg_parse_listen()
17602 - [MINOR] Free rdp_cookie_name on denint()
17603 - [MINOR] Free tcp rules on denint()
17604 - [MINOR] Free stick table pool on denint()
17605 - [MINOR] Free stick rules on denint()
17606 - [MEDIUM] Fix stick-table replication on soft-restart
17607 - [MEDIUM] Correct ipmask() logic
17608 - [MINOR] Correct type in table dump examples
17609 - [MINOR] Fix build error in stream_int_register_handler()
17610 - [MINOR] Use DPRINTF in assign_server()
17611 - [BUG] checks: http-check expect could fail a check on multi-packet responses
17612 - [DOC] fix minor typo in the "dispatch" doc
17613 - [BUG] proto_tcp: fix address binding on remote source
17614 - [MINOR] http: don't report the "haproxy" word on the monitoring response
17615 - [REORG] http: move HTTP error codes back to proto_http.h
17616 - [MINOR] http: make the "HTTP 200" status code configurable.
17617 - [MINOR] http: partially revert the chunking optimization for now
17618 - [MINOR] stream_sock: always clear BF_EXPECT_MORE upon complete transfer
17619 - [CLEANUP] stream_sock: remove unneeded FL_TCP and factor out test
17620 - [MEDIUM] http: add support for "http-no-delay"
17621 - [OPTIM] http: optimize chunking again in non-interactive mode
17622 - [OPTIM] stream_sock: avoid fast-forwarding of partial data
17623 - [OPTIM] stream_sock: don't use splice on too small payloads
17624 - [MINOR] config: make it possible to specify a cookie even without a server
17625 - [BUG] stats: support url-encoded forms
17626 - [MINOR] config: automatically compute a default fullconn value
17627 - [CLEANUP] config: remove some left-over printf debugging code from previous patch
17628 - [DOC] add missing entry or stick store-response
17629 - [MEDIUM] http: add support for 'cookie' and 'set-cookie' patterns
17630 - [BUG] halog: correctly handle truncated last line
17631 - [MINOR] halog: make SKIP_CHAR stop on field delimiters
17632 - [MINOR] halog: add support for HTTP log matching (-H)
17633 - [MINOR] halog: gain back performance before SKIP_CHAR fix
17634 - [OPTIM] halog: cache some common fields positions
17635 - [OPTIM] halog: check once for correct line format and reuse the pointer
17636 - [OPTIM] halog: remove many 'if' by using a function pointer for the filters
17637 - [OPTIM] halog: remove support for tab delimiters in input data
17638 - [BUG] session: risk of crash on out of memory (1.5-dev regression)
17639 - [MINOR] session: try to emit a 500 response on memory allocation errors
17640 - [OPTIM] stream_sock: reduce the default number of accepted connections at once
17641 - [BUG] stream_sock: disable listener when system resources are exhausted
17642 - [MEDIUM] proxy: add a PAUSED state to listeners and move socket tricks out of proxy.c
17643 - [BUG] stream_sock: ensure orphan listeners don't accept too many connections
17644 - [MINOR] listeners: add listen_full() to mark a listener full
17645 - [MINOR] listeners: add support for queueing resource limited listeners
17646 - [MEDIUM] listeners: put listeners in queue upon resource shortage
17647 - [MEDIUM] listeners: queue proxy-bound listeners at the proxy's
17648 - [MEDIUM] listeners: don't stop proxies when global maxconn is reached
17649 - [MEDIUM] listeners: don't change listeners states anymore in maintain_proxies
17650 - [CLEANUP] proxy: rename a few proxy states (PR_STIDLE and PR_STRUN)
17651 - [MINOR] stats: report a "WAITING" state for sockets waiting for resource
17652 - [MINOR] proxy: make session rate-limit more accurate
17653 - [MINOR] sessions: only wake waiting listeners up if rate limit is OK
17654 - [BUG] proxy: peers must only be stopped once, not upon every call to maintain_proxies
17655 - [CLEANUP] proxy: merge maintain_proxies() operation inside a single loop
17656 - [MINOR] task: new function task_schedule() to schedule a wake up
17657 - [MAJOR] proxy: finally get rid of maintain_proxies()
17658 - [BUG] proxy: stats frontend and peers were missing many initializers
17659 - [MEDIUM] listeners: add a global listener management task
17660 - [MINOR] proxy: make findproxy() return proxies from numeric IDs too
17661 - [DOC] fix typos, "#" is a sharp, not a dash
17662 - [MEDIUM] stats: add support for changing frontend's maxconn at runtime
17663 - [MEDIUM] checks: group health checks methods by values and save option bits
17664 - [MINOR] session-counters: add the ability to clear the counters
17665 - [BUG] check: http-check expect + regex would crash in defaults section
17666 - [MEDIUM] http: make x-forwarded-for addition conditional
17667 - [REORG] build: move syscall redefinition to specific places
17668 - [CLEANUP] update the year in the copyright banner
17669 - [BUG] possible crash in 'show table' on stats socket
17670 - [BUG] checks: use the correct destination port for sending checks
17671 - [BUG] backend: risk of picking a wrong port when mapping is used with crossed families
17672 - [MINOR] make use of set_host_port() and get_host_port() to get rid of family mismatches
17673 - [DOC] fixed a few "sensible" -> "sensitive" errors
17674 - [MINOR] make use of addr_to_str() and get_host_port() to replace many inet_ntop()
17675 - [BUG] http: trailing white spaces must also be trimmed after headers
17676 - [MINOR] stats: display "<NONE>" instead of the frontend name when unknown
17677 - [MINOR] http: take a capture of too large requests and responses
17678 - [MINOR] http: take a capture of truncated responses
17679 - [MINOR] http: take a capture of bad content-lengths.
17680 - [DOC] add a few old and uncommitted docs
17681 - [CLEANUP] cfgparse: fix reported options for the "bind" keyword
17682 - [MINOR] halog: add -hs/-HS to filter by HTTP status code range
17683 - [MINOR] halog: support backslash-escaped quotes
17684 - [CLEANUP] remove dirty left-over of a debugging message
17685 - [MEDIUM] stats: disable complex socket reservation for stats socket
17686 - [CLEANUP] remove a useless test in manage_global_listener_queue()
17687 - [MEDIUM] stats: add the "set maxconn" setting to the command line interface
17688 - [MEDIUM] add support for global.maxconnrate to limit the per-process conn rate.
17689 - [MINOR] stats: report the current and max global connection rates
17690 - [MEDIUM] stats: add the ability to adjust the global maxconnrate
17691 - [BUG] peers: don't pre-allocate 65000 connections to each peer
17692 - [MEDIUM] don't limit peers nor stats socket to maxconn nor maxconnrate
17693 - [BUG] peers: the peer frontend must not emit any log
17694 - [CLEANUP] proxy: make pause_proxy() perform the required controls and emit the logs
17695 - [BUG] peers: don't keep a peers section which has a NULL frontend
17696 - [BUG] peers: ensure the peers are resumed if they were paused
17697 - [MEDIUM] stats: add the ability to enable/disable/shutdown a frontend at runtime
17698 - [MEDIUM] session: make session_shutdown() an independant function
17699 - [MEDIUM] stats: offer the possibility to kill a session from the CLI
17700 - [CLEANUP] stats: centralize tests for backend/server inputs on the CLI
17701 - [MEDIUM] stats: offer the possibility to kill sessions by server
17702 - [MINOR] halog: do not consider byte 0x8A as end of line
17703 - [MINOR] frontend: ensure debug message length is always initialized
17704 - [OPTIM] halog: make fgets parse more bytes by blocks
17705 - [OPTIM] halog: add assembly version of the field lookup code
17706 - [MEDIUM] poll: add a measurement of idle vs work time
17707 - [CLEANUP] startup: report only the basename in the usage message
17708 - [MINOR] startup: add an option to change to a new directory
17709 - [OPTIM] task: don't scan the run queue if we know it's empty
17710 - [BUILD] stats: stdint is not present on solaris
17711 - [DOC] update the README file to reflect new naming rules for patches
17712 - [MINOR] stats: report the number of requests intercepted by the frontend
17713 - [DOC] update ROADMAP file
17714
Willy Tarreau04df1122011-04-08 00:56:41 +0200177152011/04/08 : 1.5-dev6
17716 - [BUG] stream_sock: use get_addr_len() instead of sizeof() on sockaddr_storage
17717 - [BUG] TCP source tracking was broken with IPv6 changes
17718 - [BUG] stick-tables did not work when converting IPv6 to IPv4
17719 - [CRITICAL] fix risk of crash when dealing with space in response cookies
17720
Willy Tarreaub06ed2c2011-03-29 01:10:33 +0200177212011/03/29 : 1.5-dev5
17722 - [BUG] standard: is_addr return value for IPv4 was inverted
17723 - [MINOR] update comment about IPv6 support for server
17724 - [MEDIUM] use getaddrinfo to resolve names if gethostbyname fail
17725 - [DOC] update IPv6 support for bind
17726 - [DOC] document IPv6 support for server
17727 - [DOC] fix a minor typo
17728 - [MEDIUM] IPv6 support for syslog
17729 - [DOC] document IPv6 support for syslog
17730 - [MEDIUM] IPv6 support for stick-tables
17731 - [DOC] document IPv6 support for stick-tables
17732 - [DOC] update ROADMAP file
17733 - [BUG] session: src_conn_cur was returning src_conn_cnt instead
17734 - [MINOR] frontend: add a make_proxy_line function
17735 - [MEDIUM] stream_sock: add support for sending the proxy protocol header line
17736 - [MEDIUM] server: add support for the "send-proxy" option
17737 - [DOC] update the spec on the proxy protocol
17738 - [BUILD] proto_tcp: fix build issue with CTTPROXY
17739 - [DOC] update ROADMAP file
17740 - [MEDIUM] config: rework the IPv4/IPv6 address parser to support host-only addresses
17741 - [MINOR] cfgparse: better report wrong listening addresses and make use of str2sa_range
17742 - [BUILD] add the USE_GETADDRINFO build option
17743 - [TESTS] provide a test case for various address formats
17744 - [BUG] session: conn_retries was not always initialized
17745 - [BUG] log: retrieve the target from the session, not the SI
17746 - [BUG] http: fix possible incorrect forwarded wrapping chunk size (take 2)
17747 - [MINOR] tools: add two macros MID_RANGE and MAX_RANGE
17748 - [BUG] http: fix content-length handling on 32-bit platforms
17749 - [OPTIM] buffers: uninline buffer_forward()
17750 - [BUG] stream_sock: fix handling for server side PROXY protocol
17751 - [MINOR] acl: add support for table_cnt and table_avl matches
17752 - [DOC] update ROADMAP file
17753
Willy Tarreaue0052cc2011-03-13 22:15:02 +0100177542011/03/13 : 1.5-dev4
17755 - [MINOR] cfgparse: Check whether the path given for the stats socket actually fits into the sockaddr_un structure to avoid truncation.
17756 - [MINOR] unix sockets : inherits the backlog size from the listener
17757 - [CLEANUP] unix sockets : move create_uxst_socket() in uxst_bind_listener()
17758 - [DOC] fix a minor typo
17759 - [DOC] fix ignore-persist documentation
17760 - [MINOR] add warnings on features not compatible with multi-process mode
17761 - [BUG] http: fix http-pretend-keepalive and httpclose/tunnel mode
17762 - [MINOR] stats: add support for several packets in stats admin
17763 - [BUG] stats: admin commands must check the proxy state
17764 - [BUG] stats: admin web interface must check the proxy state
17765 - [MINOR] http: add pattern extraction method to stick on query string parameter
17766 - [MEDIUM] add internal support for IPv6 server addresses
17767 - [MINOR] acl: add be_id/srv_id to match backend's and server's id
17768 - [MINOR] log: add support for passing the forwarded hostname
17769 - [MINOR] log: ability to override the syslog tag
17770 - [MINOR] checks: add PostgreSQL health check
17771 - [DOC] update ROADMAP file
17772 - [BUILD] pattern: use 'int' instead of 'int32_t'
17773 - [OPTIM] linux: add support for bypassing libc to force using vsyscalls
17774 - [BUG] debug: report the correct poller list in verbose mode
17775 - [BUG] capture: do not capture a cookie if there is no memory left
17776 - [BUG] appsession: fix possible double free in case of out of memory
17777 - [CRITICAL] cookies: mixing cookies in indirect mode and appsession can crash the process
17778 - [BUG] http: correctly update the header list when removing two consecutive headers
17779 - [BUILD] add the CPU=native and ARCH=32/64 build options
17780 - [BUILD] add -fno-strict-aliasing to fix warnings with gcc >= 4.4
17781 - [CLEANUP] hash: move the avalanche hash code globally available
17782 - [MEDIUM] hash: add support for an 'avalanche' hash-type
17783 - [DOC] update roadmap file
17784 - [BUG] http: do not re-enable the PROXY analyser on keep-alive
17785 - [OPTIM] http: don't send each chunk in a separate packet
17786 - [DOC] fix minor typos reported recently in the peers section
17787 - [DOC] fix another typo in the doc
17788 - [MINOR] stats: report HTTP message state and buffer flags in error dumps
17789 - [BUG] http chunking: don't report a parsing error on connection errors
17790 - [BUG] stream_interface: truncate buffers when sending error messages
17791 - [MINOR] http: support wrapping messages in error captures
17792 - [MINOR] http: capture incorrectly chunked message bodies
17793 - [MINOR] stats: add global event ID and count
17794 - [BUG] http: analyser optimizations broke pipelining
17795 - [CLEANUP] frontend: only apply TCP-specific settings to TCP/TCP6 sockets
17796 - [BUG] http: fix incorrect error reporting during data transfers
17797 - [CRITICAL] session: correctly leave turn-around and queue states on abort
17798 - [BUG] session: release slot before processing pending connections
17799 - [MINOR] tcp: add support for dynamic MSS setting
17800 - [BUG] stick-table: correctly terminate string keys during lookups
17801 - [BUG] acl: fix handling of empty lines in pattern files
17802 - [BUG] stick-table: use the private buffer when padding strings
17803 - [BUG] ebtree: fix ebmb_lookup() with len smaller than the tree's keys
17804 - [OPTIM] ebtree: ebmb_lookup: reduce stack usage by moving the return code out of the loop
17805 - [OPTIM] ebtree: inline ebst_lookup_len and ebis_lookup_len
17806 - [REVERT] undo the stick-table string key lookup fixes
17807 - [MINOR] http: improve url_param pattern extraction to ignore empty values
17808 - [BUILD] frontend: shut a warning with TCP_MAXSEG
17809 - [BUG] http: update the header list's tail when removing the last header
17810 - [DOC] fix minor typo in the proxy protocol doc
17811 - [DOC] fix typos (http-request instead of http-check)
17812 - [BUG] http: use correct ACL pointer when evaluating authentication
17813 - [BUG] cfgparse: correctly count one socket per port in ranges
17814 - [BUG] startup: set the rlimits before binding ports, not after.
17815 - [BUG] acl: srv_id must return no match when the server is NULL
17816 - [MINOR] acl: add ability to check for internal response-only parameters
17817 - [MINOR] acl: srv_id is only valid in responses
17818 - [MINOR] config: warn if response-only conditions are used in "redirect" rules
17819 - [BUG] acl: fd leak when reading patterns from file
17820 - [DOC] fix minor typo in "usesrc"
17821 - [BUG] http: fix possible incorrect forwarded wrapping chunk size
17822 - [BUG] http: fix computation of message body length after forwarding has started
17823 - [BUG] http: balance url_param did not work with first parameters on POST
17824 - [TESTS] update the url_param regression test to test check_post too
17825 - [DOC] update ROADMAP
17826 - [DOC] internal: reflect the fact that SI_ST_ASS is transient
17827 - [BUG] config: don't crash on empty pattern files.
17828 - [MINOR] stream_interface: make use of an applet descriptor for IO handlers
17829 - [REORG] stream_interface: move the st0, st1 and private members to the applet
17830 - [REORG] stream_interface: split the struct members in 3 parts
17831 - [REORG] session: move client and server address to the stream interface
17832 - [REORG] tcp: make tcpv4_connect_server() take the target address from the SI
17833 - [MEDIUM] stream_interface: store the target pointer and type
17834 - [CLEANUP] stream_interface: remove the applet.handler pointer
17835 - [MEDIUM] log: take the logged server name from the stream interface
17836 - [CLEANUP] session: remove data_source from struct session
17837 - [CLEANUP] stats: make all dump functions only rely on the stream interface
17838 - [REORG] session: move the data_ctx struct to the stream interface's applet
17839 - [MINOR] proxy: add PR_O2_DISPATCH to detect dispatch mode
17840 - [MINOR] cfgparse: only keep one of dispatch, transparent, http_proxy
17841 - [MINOR] session: add a pointer to the new target into the session
17842 - [MEDIUM] session: remove s->prev_srv which is not needed anymore
17843 - [CLEANUP] stream_interface: use inline functions to manipulate targets
17844 - [MAJOR] session: remove the ->srv pointer from struct session
17845 - [MEDIUM] stats: split frontend and backend stats
17846 - [MEDIUM] http: always evaluate http-request rules before stats http-request
17847 - [REORG] http: move the http-request rules to proto_http
17848 - [BUG] http: stats were not incremented on http-request deny
17849 - [MINOR] checks: report it if checks fail due to socket creation error
17850
Willy Tarreau442e8342010-11-11 23:29:35 +0100178512010/11/11 : 1.5-dev3
17852 - [DOC] fix http-request documentation
17853 - [MEDIUM] enable/disable servers from the stats web interface
17854 - [MEDIUM] stats: add an admin level
17855 - [DOC] stats: document the "stats admin" statement
17856 - [MINOR] startup: print the proxy socket which caused an error
17857 - [CLEANUP] Remove unneeded chars allocation
17858 - [MINOR] config: detect options not supported due to compilation options
17859 - [MINOR] Add pattern's fetchs payload and payload_lv
17860 - [MINOR] frontend: improve accept-proxy header parsing
17861 - [MINOR] frontend: add tcpv6 support on accept-proxy bind
17862 - [MEDIUM] Enhance message errors management on binds
17863 - [MINOR] Manage unix socket source field on logs
17864 - [MINOR] Manage unix socket source field on session dump on sock stats
17865 - [MINOR] Support of unix listener sockets for debug and log event messages on frontend.c
17866 - [MINOR] Add some tests on sockets family for port remapping and mode transparent.
17867 - [MINOR] Manage socket type unix for some logs
17868 - [MINOR] Enhance controls of socket's family on acls and pattern fetch
17869 - [MINOR] Support listener's sockets unix on http logs.
17870 - [MEDIUM] Add supports of bind on unix sockets.
17871 - [BUG] stick table purge failure if size less than 255
17872 - [BUG] stick table entries expire on counters updates/read or show table, even if there is no "expire" parameter
17873 - [MEDIUM] Implement tcp inspect response rules
17874 - [DOC] tcp-response content and inspect
17875 - [MINOR] new acls fetch req_ssl_hello_type and rep_ssl_hello_type
17876 - [DOC] acls rep_ssl_hello and req_ssl_hello
17877 - [MEDIUM] Create new protected pattern types CONSTSTRING and CONSTDATA to force memcpy if data from protected areas need to be manipulated.
17878 - [DOC] new type binary in stick-table
17879 - [DOC] stick store-response and new patterns payload and payload_lv
17880 - [MINOR] Manage all types (ip, integer, string, binary) on cli "show table" command
17881 - [MEDIUM] Create updates tree on stick table to manage sync.
17882 - [MAJOR] Add new files src/peer.c, include/proto/peers.h and include/types/peers.h for sync stick table management
17883 - [MEDIUM] Manage peers section parsing and stick table registration on peers.
17884 - [MEDIUM] Manage soft stop on peers proxy
17885 - [DOC] add documentation for peers section
17886 - [MINOR] checks: add support for LDAPv3 health checks
17887 - [MINOR] add better support to "mysql-check"
17888 - [BUG] Restore info about available active/backup servers
17889 - [CONTRIB] Update haproxy.pl
17890 - [CONTRIB] Update Cacti Tempates
17891 - [CONTRIB] add templates for Cacti.
17892 - [BUG] http: don't consider commas as a header delimitor within quotes
17893 - [MINOR] support a global jobs counter
17894 - [DOC] add a summary about cookie incompatibilities between specs and browsers
17895 - [DOC] fix description of cookie "insert" and "indirect" modes
17896 - [MEDIUM] http: fix space handling in the request cookie parser
17897 - [MEDIUM] http: fix space handling in the response cookie parser
17898 - [DOC] fix typo in the queue() definition (backend, not frontend)
17899 - [BUG] deinit: unbind listeners before freeing them
17900 - [BUG] stream_interface: only call si->release when both dirs are closed
17901 - [MEDIUM] buffers: rework the functions to exchange between SI and buffers
17902 - [DOC] fix typo in the avg_queue() and be_conn() definition (backend, not frontend)
17903 - [MINOR] halog: add '-tc' to sort by termination codes
17904 - [MINOR] halog: skip non-traffic logs for -st and -tc
17905 - [BUG] stream_sock: cleanly disable the listener in case of resource shortage
17906 - [BUILD] stream_sock: previous fix lacked the #include, causing a warning.
17907 - [DOC] bind option is "defer-accept", not "defer_accept"
17908 - [DOC] missing index entry for http-check send-state
17909 - [DOC] tcp-request inspect-delay is for backends too
17910 - [BUG] ebtree: string_equal_bits() could return garbage on identical strings
17911 - [BUG] stream_sock: try to flush any extra pending request data after a POST
17912 - [BUILD] proto_http: eliminate some build warnings with gcc-2.95
17913 - [MEDIUM] make it possible to combine http-pretend-keepalived with httpclose
17914 - [MEDIUM] tcp-request : don't wait for inspect-delay to expire when the buffer is full
17915 - [MEDIUM] checks: add support for HTTP contents lookup
17916 - [TESTS] add test-check-expect to test various http-check methods
17917 - [MINOR] global: add "tune.chksize" to change the default check buffer size
17918 - [MINOR] cookie: add options "maxidle" and "maxlife"
17919 - [MEDIUM] cookie: support client cookies with some contents appended to their value
17920 - [MINOR] http: make some room in the transaction flags to extend cookies
17921 - [MINOR] cookie: add the expired (E) and old (O) flags for request cookies
17922 - [MEDIUM] cookie: reassign set-cookie status flags to store more states
17923 - [MINOR] add encode/decode function for 30-bit integers from/to base64
17924 - [MEDIUM] cookie: check for maxidle and maxlife for incoming dated cookies
17925 - [MEDIUM] cookie: set the date in the cookie if needed
17926 - [DOC] document the cookie maxidle and maxlife parameters
17927 - [BUG] checks: don't log backend down for all zero-weight servers
17928 - [MEDIUM] checks: set server state to one state from failure when leaving maintenance
17929 - [BUG] config: report correct keywords for "observe"
17930 - [MINOR] checks: ensure that we can inherit binary checks from the defaults section
17931 - [MINOR] acl: add the http_req_first match
17932 - [DOC] fix typos about bind-process syntax
17933 - [BUG] cookie: correctly unset default cookie parameters
17934 - [MINOR] cookie: add support for the "preserve" option
17935 - [BUG] ebtree: fix duplicate strings insertion
17936 - [CONTRIB] halog: report per-url counts, errors and times
17937 - [CONTRIB] halog: minor speed improvement in timer parser
17938 - [MINOR] buffers: add a new request analyser flag for PROXY mode
17939 - [MINOR] listener: add the "accept-proxy" option to the "bind" keyword
17940 - [MINOR] standard: add read_uint() to parse a delimited unsigned integer
17941 - [MINOR] standard: change arg type from const char* to char*
17942 - [MINOR] frontend: add a new analyser to parse a proxied connection
17943 - [MEDIUM] session: call the frontend_decode_proxy analyser on proxied connections
17944 - [DOC] add the proxy protocol's specifications
17945 - [DOC] document the 'accept-proxy' bind option
17946 - [MINOR] cfgparse: report support of <path> for the 'bind' statements
17947 - [DOC] add references to unix socket handling
17948 - [MINOR] move MAXPATHLEN definition to compat.h
17949 - [MEDIUM] unix sockets: cleanup the error reporting path
17950 - [BUG] session: don't stop forwarding of data upon last packet
17951 - [CLEANUP] accept: replace some inappropriate Alert() calls with send_log()
17952 - [BUILD] peers: shut a printf format warning (key_size is a size_t)
17953 - [BUG] accept: don't close twice upon error
17954 - [OPTIM] session: don't recheck analysers when buffer flags have not changed
17955 - [OPTIM] stream_sock: don't clear FDs that are already cleared
17956 - [BUG] proto_tcp: potential bug on pattern fetch dst and dport
17957
Willy Tarreau37242fa2010-08-28 19:21:00 +0200179582010/08/28 : 1.5-dev2
17959 - [MINOR] startup: release unused structs after forking
17960 - [MINOR] startup: don't wait for nothing when no old pid remains
17961 - [CLEANUP] reference product branch 1.5
17962 - [MEDIUM] signals: add support for registering functions and tasks
17963 - [MEDIUM] signals: support redistribution of signal zero when stopping
17964 - [BUG] http: don't set auto_close if more data are expected
17965
Willy Tarreaufc815fd2010-08-25 10:56:53 +0200179662010/08/25 : 1.5-dev1
17967 - [BUG] stats: session rate limit gets garbaged in the stats
17968 - [DOC] mention 'option http-server-close' effect in Tq section
17969 - [DOC] summarize and highlight persistent connections behaviour
17970 - [DOC] add configuration samples
17971 - [BUG] http: dispatch and http_proxy modes were broken for a long time
17972 - [BUG] http: the transaction must be initialized even in TCP mode
17973 - [BUG] tcp: dropped connections must be counted as "denied" not "failed"
17974 - [BUG] consistent hash: balance on all servers, not only 2 !
17975 - [CONTRIB] halog: report per-server status codes, errors and response times
17976 - [BUG] http: the transaction must be initialized even in TCP mode (part 2)
17977 - [BUG] client: always ensure to zero rep->analysers
17978 - [BUG] session: clear BF_READ_ATTACHED before next I/O
17979 - [BUG] http: automatically close response if req is aborted
17980 - [BUG] proxy: connection rate limiting was eating lots of CPU
17981 - [BUG] http: report correct flags in case of client aborts during body
17982 - [TESTS] refine non-regression tests and add 4 new tests
17983 - [BUG] debug: wrong pointer was used to report a status line
17984 - [BUG] debug: correctly report truncated messages
17985 - [DOC] document the "dispatch" keyword
17986 - [BUG] stick_table: fix possible memory leak in case of connection error
17987 - [CLEANUP] acl: use 'L6' instead of 'L4' in ACL flags relying on contents
17988 - [MINOR] accept: count the incoming connection earlier
17989 - [CLEANUP] tcp: move some non tcp-specific layer6 processing out of proto_tcp
17990 - [CLEANUP] client: move some ACLs away to their respective locations
17991 - [CLEANUP] rename client -> frontend
17992 - [MEDIUM] separate protocol-level accept() from the frontend's
17993 - [MINOR] proxy: add a list to hold future layer 4 rules
17994 - [MEDIUM] config: parse tcp layer4 rules (tcp-request accept/reject)
17995 - [MEDIUM] tcp: check for pure layer4 rules immediately after accept()
17996 - [OPTIM] frontend: tell the compiler that errors are unlikely to occur
17997 - [MEDIUM] frontend: check for LI_O_TCP_RULES in the listener
17998 - [MINOR] frontend: only check for monitor-net rules if LI_O_CHK_MONNET is set
17999 - [CLEANUP] buffer->cto is not used anymore
18000 - [MEDIUM] session: finish session establishment sequence in with I/O handlers
18001 - [MEDIUM] session: initialize server-side timeouts after connect()
18002 - [MEDIUM] backend: initialize the server stream_interface upon connect()
18003 - [MAJOR] frontend: don't initialize the server-side stream_int anymore
18004 - [MEDIUM] session: move the conn_retries attribute to the stream interface
18005 - [MEDIUM] session: don't assign conn_retries upon accept() anymore
18006 - [MINOR] frontend: rely on the frontend and not the backend for INDEPSTR
18007 - [MAJOR] frontend: reorder the session initialization upon accept
18008 - [MINOR] proxy: add an accept() callback for the application layer
18009 - [MAJOR] frontend: split accept() into frontend_accept() and session_accept()
18010 - [MEDIUM] stats: rely on the standard session_accept() function
18011 - [MINOR] buffer: refine the flags that may wake an analyser up.
18012 - [MINOR] stream_sock: don't dereference a non-existing frontend
18013 - [MINOR] session: differenciate between accepted connections and received connections
18014 - [MEDIUM] frontend: count the incoming connection earlier
18015 - [MINOR] frontend: count denied TCP requests separately
18016 - [CLEANUP] stick_table: add/clarify some comments
18017 - [BUILD] memory: add a few missing parenthesis to the pool management macros
18018 - [MINOR] stick_table: add support for variable-sized data
18019 - [CLEANUP] stick_table: rename some stksess struct members to avoid confusion
18020 - [CLEANUP] stick_table: move pattern to key functions to stick_table.c
18021 - [MEDIUM] stick_table: add room for extra data types
18022 - [MINOR] stick_table: add support for "conn_cum" data type.
18023 - [MEDIUM] stick_table: don't overwrite data when storing an entry
18024 - [MINOR] config: initialize stick tables after all the parsing
18025 - [MINOR] stick_table: provide functions to return stksess data from a type
18026 - [MEDIUM] stick_table: move the server ID to a generic data type
18027 - [MINOR] stick_table: enable it for frontends too
18028 - [MINOR] stick_table: export the stick_table_key
18029 - [MINOR] tcp: add per-source connection rate limiting
18030 - [MEDIUM] stick_table: separate storage and update of session entries
18031 - [MEDIUM] stick-tables: add a reference counter to each entry
18032 - [MINOR] session: add a pointer to the tracked counters for the source
18033 - [CLEANUP] proto_tcp: make the config parser a little bit more flexible
18034 - [BUG] config: report the correct proxy type in tcp-request errors
18035 - [MINOR] config: provide a function to quote args in a more friendly way
18036 - [BUG] stick_table: the fix for the memory leak caused a regression
18037 - [MEDIUM] backend: support servers on 0.0.0.0
18038 - [BUG] stick-table: correctly refresh expiration timers
18039 - [MEDIUM] stream-interface: add a ->release callback
18040 - [MINOR] proxy: add a "parent" member to the structure
18041 - [MEDIUM] session: make it possible to call an I/O handler on both SI
18042 - [MINOR] tools: add a fast div64_32 function
18043 - [MINOR] freq_ctr: add new types and functions for periods different from 1s
18044 - [MINOR] errors: provide new status codes for config parsing functions
18045 - [BUG] http: denied requests must not be counted as denied resps in listeners
18046 - [MINOR] tools: add a get_std_op() function to parse operators
18047 - [MEDIUM] acl: make use of get_std_op() to parse intger ranges
18048 - [MAJOR] stream_sock: better wakeup conditions on read()
18049 - [BUG] session: analysers must be checked when SI state changes
18050 - [MINOR] http: reset analysers to listener's, not frontend's
18051 - [MEDIUM] session: support "tcp-request content" rules in backends
18052 - [BUILD] always match official tags when doing git-tar
18053 - [MAJOR] stream_interface: fix the wakeup conditions for embedded iohandlers
18054 - [MEDIUM] buffer: make buffer_feed* support writing non-contiguous chunks
18055 - [MINOR] tcp: src_count acl does not have a permanent result
18056 - [MAJOR] session: add track-counters to track counters related to the session
18057 - [MINOR] stick-table: provide a table lookup function
18058 - [MINOR] stick-table: use suffix "_cnt" for cumulated counts
18059 - [MEDIUM] session: move counter ACL fetches from proto_tcp
18060 - [MEDIUM] session: add concurrent connections counter
18061 - [MEDIUM] session: add data in and out volume counters
18062 - [MINOR] session: add the trk_conn_cnt ACL keyword to track connection counts
18063 - [MEDIUM] session-counters: automatically update tracked connection count
18064 - [MINOR] session: add the trk_conn_cur ACL keyword to track concurrent connection
18065 - [MINOR] session: add trk_kbytes_* ACL keywords to track data size
18066 - [MEDIUM] session: add a counter on the cumulated number of sessions
18067 - [MINOR] config: support a comma-separated list of store data types in stick-table
18068 - [MEDIUM] stick-tables: add support for arguments to data_types
18069 - [MEDIUM] stick-tables: add stored data argument type checking
18070 - [MEDIUM] session counters: add conn_rate and sess_rate counters
18071 - [MEDIUM] session counters: add bytes_in_rate and bytes_out_rate counters
18072 - [MINOR] stktable: add a stktable_update_key() function
18073 - [MINOR] session-counters: add a general purpose counter (gpc0)
18074 - [MEDIUM] session-counters: add HTTP req/err tracking
18075 - [MEDIUM] stats: add "show table [<name>]" to dump a stick-table
18076 - [MEDIUM] stats: add "clear table <name> key <value>" to clear table entries
18077 - [CLEANUP] stick-table: declare stktable_data_types as extern
18078 - [MEDIUM] stick-table: make use of generic types for stored data
18079 - [MINOR] stats: correctly report errors on "show table" and "clear table"
18080 - [MEDIUM] stats: add the ability to dump table entries matching criteria
18081 - [DOC] configuration: document all the new tracked counters
18082 - [DOC] stats: document "show table" and "clear table"
18083 - [MAJOR] session-counters: split FE and BE track counters
18084 - [MEDIUM] tcp: accept the "track-counters" in "tcp-request content" rules
18085 - [MEDIUM] session counters: automatically remove expired entries.
18086 - [MEDIUM] config: replace 'tcp-request <action>' with "tcp-request connection"
18087 - [MEDIUM] session-counters: make it possible to count connections from frontend
18088 - [MINOR] session-counters: use "track-sc{1,2}" instead of "track-{fe,be}-counters"
18089 - [MEDIUM] session-counters: correctly unbind the counters tracked by the backend
18090 - [CLEANUP] stats: use stksess_kill() to remove table entries
18091 - [DOC] update the references to session counters and to tcp-request connection
18092 - [DOC] cleanup: split a few long lines
18093 - [MEDIUM] http: forward client's close when abortonclose is set
18094 - [BUG] queue: don't dequeue proxy-global requests on disabled servers
18095 - [BUG] stats: global stats timeout may be specified before stats socket.
18096 - [BUG] conf: add tcp-request content rules to the correct list
18097
Willy Tarreau21475e32010-05-23 08:46:08 +0200180982010/05/23 : 1.5-dev0
18099 - exact copy of 1.4.6
18100
Willy Tarreau5fdd77d2010-05-16 22:34:28 +0200181012010/05/16 : 1.4.6
18102 - [BUILD] ebtree: update to v6.0.1 to remove references to dprintf()
18103 - [CLEANUP] acl: make use of eb_is_empty() instead of open coding the tree's emptiness test
18104 - [MINOR] acl: add srv_is_up() to check that a specific server is up or not
18105 - [DOC] add a few precisions about the use of RDP cookies
18106
Willy Tarreau9d4d9e32010-05-13 22:17:08 +0200181072010/05/13 : 1.4.5
18108 - [DOC] report minimum kernel version for tproxy in the Makefile
18109 - [MINOR] add the "ignore-persist" option to conditionally ignore persistence
18110 - [DOC] add the "ignore-persist" option to conditionally ignore persistence
18111 - [DOC] fix ignore-persist/force-persist documentation
18112 - [BUG] cttproxy: socket fd leakage in check_cttproxy_version
18113 - [DOC] doc/configuration.txt: fix typos
18114 - [MINOR] option http-pretend-keepalive is both for FEs and BEs
18115 - [MINOR] fix possible crash in debug mode with invalid responses
18116 - [MINOR] halog: add support for statisticts on status codes
18117 - [OPTIM] halog: use a faster zero test in fgets()
18118 - [OPTIM] halog: minor speedup by using unlikely()
18119 - [OPTIM] halog: speed up fgets2-64 by about 10%
18120 - [DOC] refresh the README file and merge the CONTRIB file into it
18121 - [MINOR] acl: support loading values from files
18122 - [MEDIUM] ebtree: upgrade to version 6.0
18123 - [MINOR] acl trees: add flags and union members to store values in trees
18124 - [MEDIUM] acl: add ability to insert patterns in trees
18125 - [MEDIUM] acl: add tree-based lookups of exact strings
18126 - [MEDIUM] acl: add tree-based lookups of networks
18127 - [MINOR] acl: ignore empty lines and comments in pattern files
18128 - [MINOR] stick-tables: add support for "stick on hdr"
18129
Willy Tarreau9508c1c2010-04-07 23:12:24 +0200181302010/04/07 : 1.4.4
18131 - [BUG] appsession should match the whole cookie name
18132 - [CLEANUP] proxy: move PR_O_SSL3_CHK to options2 to release one flag
18133 - [MEDIUM] backend: move the transparent proxy address selection to backend
18134 - [MINOR] add very fast IP parsing functions
18135 - [MINOR] add new tproxy flags for dynamic source address binding
18136 - [MEDIUM] add ability to connect to a server from an IP found in a header
18137 - [BUILD] config: last patch breaks build without CONFIG_HAP_LINUX_TPROXY
18138 - [MINOR] http: make it possible to pretend keep-alive when doing close
18139 - [MINOR] config: report "default-server" instead of "(null)" in error messages
18140
Willy Tarreau75934a12010-03-30 09:50:08 +0200181412010/03/30 : 1.4.3
18142 - [CLEANUP] stats: remove printf format warning in stats_dump_full_sess_to_buffer()
18143 - [MEDIUM] session: better fix for connection to servers with closed input
18144 - [DOC] indicate in the doc how to bind to port ranges
18145 - [BUG] backend: L7 hashing must not be performed on incomplete requests
18146 - [TESTS] add a simple program to test connection resets
18147 - [MINOR] cli: "show errors" should display "backend <NONE>" when backend was not used
18148 - [MINOR] config: emit warnings when HTTP-only options are used in TCP mode
18149 - [MINOR] config: allow "slowstart 0s"
18150 - [BUILD] 'make tags' did not consider files ending in '.c'
18151 - [MINOR] checks: add the ability to disable a server in the config
18152
Willy Tarreauda618cb2010-03-17 23:41:57 +0100181532010/03/17 : 1.4.2
18154 - [CLEANUP] product branch update
18155 - [DOC] Some more documentation cleanups
18156 - [BUG] clf logs segfault when capturing a non existant header
18157 - [OPTIM] config: only allocate check buffer when checks are enabled
18158 - [MEDIUM] checks: support multi-packet health check responses
18159 - [CLEANUP] session: remove duplicate test
18160 - [BUG] http: don't wait for response data to leave buffer is client has left
18161 - [MINOR] proto_uxst: set accept_date upon accept() to the wall clock time
18162 - [MINOR] stats: don't send empty lines in "show errors"
18163 - [MINOR] stats: make the data dump function reusable for other purposes
18164 - [MINOR] stats socket: add show sess <id> to dump details about a session
18165 - [BUG] stats: connection reset counters must be plain ascii, not HTML
18166 - [BUG] url_param hash may return a down server
18167 - [MINOR] force null-termination of hostname
18168 - [MEDIUM] connect to servers even when the input has already been closed
18169 - [BUG] don't merge anonymous ACLs !
18170 - [BUG] config: fix endless loop when parsing "on-error"
18171 - [MINOR] http: don't mark a server as failed when it returns 501/505
18172 - [OPTIM] checks: try to detect the end of response without polling again
18173 - [BUG] checks: don't report an error when recv() returns an error after data
18174 - [BUG] checks: don't abort when second poll returns an error
18175 - [MINOR] checks: make shutdown() silently fail
18176 - [BUG] http: fix truncated responses on chunk encoding when size divides buffer size
18177 - [BUG] init: unconditionally catch SIGPIPE
18178 - [BUG] checks: don't wait for a close to start parsing the response
18179
Willy Tarreauc5e60c32010-03-04 23:39:19 +0100181802010/03/04 : 1.4.1
18181 - [BUG] Clear-cookie path issue
18182 - [DOC] fix typo on stickiness rules
18183 - [BUILD] fix BSD and OSX makefiles for missing files
18184 - [BUILD] includes order breaks OpenBSD build
18185 - [BUILD] fix some build warnings on Solaris with is* macros
18186 - [BUG] logs: don't report "last data" when we have just closed after an error
18187 - [BUG] logs: don't report "proxy request" when server closes early
18188 - [BUILD] fix platform-dependant build issues related to crypt()
18189 - [STATS] count transfer aborts caused by client and by server
18190 - [STATS] frontend requests were not accounted for failed requests
18191 - [MINOR] report total number of processed connections when stopping a proxy
18192 - [DOC] be more clear about the limitation to one single monitor-net entry
18193
Willy Tarreaue18fdfd2010-02-26 14:55:22 +0100181942010/02/26 : 1.4.0
18195 - [MINOR] stats: report maint state for tracking servers too
18196 - [DOC] fix summary to add pattern extraction
18197 - [DOC] Documentation cleanups
18198 - [BUG] cfgparse memory leak and missing free calls in deinit()
18199 - [BUG] pxid/puid/luid: don't shift IDs when some of them are forced
18200 - [EXAMPLES] add auth.cfg
18201 - [BUG] uri_auth: ST_SHLGNDS should be 0x00000008 not 0x0000008
18202 - [BUG] uri_auth: do not attemp to convert uri_auth -> http-request more than once
18203 - [BUILD] auth: don't use unnamed unions
18204 - [BUG] config: report unresolvable host names as errors
18205 - [BUILD] fix build breakage with DEBUG_FULL
18206 - [DOC] fix a typo about timeout check and clarify the explanation.
18207 - [MEDIUM] http: don't use trash to realign large buffers
18208 - [STATS] report HTTP requests (total and rate) in frontends
18209 - [STATS] separate frontend and backend HTTP stats
18210 - [MEDIUM] http: revert to use a swap buffer for realignment
18211 - [MINOR] stats: report the request rate in frontends as cell titles
18212 - [MINOR] stats: mark areas with an underline when tooltips are available
18213 - [DOC] reorder some entries to maintain the alphabetical order
18214 - [DOC] cleanup of the keyword matrix
18215
Willy Tarreaub05613d2010-02-02 10:18:28 +0100182162010/02/02 : 1.4-rc1
18217 - [MEDIUM] add a maintenance mode to servers
18218 - [MINOR] http-auth: last fix was wrong
18219 - [CONTRIB] add base64rev-gen.c that was used to generate the base64rev table.
18220 - [MINOR] Base64 decode
18221 - [MINOR] generic auth support with groups and encrypted passwords
18222 - [MINOR] add ACL_TEST_F_NULL_MATCH
18223 - [MINOR] http-request: allow/deny/auth support for frontend/backend/listen
18224 - [MINOR] acl: add http_auth and http_auth_group
18225 - [MAJOR] use the new auth framework for http stats
18226 - [DOC] add info about userlists, http-request and http_auth/http_auth_group acls
18227 - [STATS] make it possible to change a CLI connection timeout
18228 - [BUG] patterns: copy-paste typo in type conversion arguments
18229 - [MINOR] pattern: make the converter more flexible by supporting void* and int args
18230 - [MINOR] standard: str2mask: string to netmask converter
18231 - [MINOR] pattern: add support for argument parsers for converters
18232 - [MINOR] pattern: add the "ipmask()" converting function
18233 - [MINOR] config: off-by-one in "stick-table" after list of converters
18234 - [CLEANUP] acl, patterns: make use of my_strndup() instead of malloc+memcpy
18235 - [BUG] restore accidentely removed line in last patch !
18236 - [MINOR] checks: make the HTTP check code add the CRLF itself
18237 - [MINOR] checks: add the server's status in the checks
18238 - [BUILD] halog: make without arch-specific optimizations
18239 - [BUG] halog: fix segfault in case of empty log in PCT mode (cherry picked from commit fe362fe4762151d209b9656639ee1651bc2b329d)
18240 - [MINOR] http: disable keep-alive when process is going down
18241 - [MINOR] acl: add build_acl_cond() to make it easier to add ACLs in config
18242 - [CLEANUP] config: use build_acl_cond() instead of parse_acl_cond()
18243 - [CLEANUP] config: use warnif_cond_requires_resp() to check for bad ACLs
18244 - [MINOR] prepare req_*/rsp_* to receive a condition
18245 - [CLEANUP] config: specify correct const char types to warnif_* functions
18246 - [MEDIUM] config: factor out the parsing of 20 req*/rsp* keywords
18247 - [MEDIUM] http: make the request filter loop check for optional conditions
18248 - [MEDIUM] http: add support for conditional request filter execution
18249 - [DOC] add some build info about the AIX platform (cherry picked from commit e41914c77edbc40aebf827b37542d37d758e371e)
18250 - [MEDIUM] http: add support for conditional request header addition
18251 - [MEDIUM] http: add support for conditional response header rewriting
18252 - [DOC] add some missing ACLs about response header matching
18253 - [MEDIUM] http: add support for proxy authentication
18254 - [MINOR] http-auth: make the 'unless' keyword work as expected
18255 - [CLEANUP] config: use build_acl_cond() to simplify http-request ACL parsing
18256 - [MEDIUM] add support for anonymous ACLs
18257 - [MEDIUM] http: switch to tunnel mode after status 101 responses
18258 - [MEDIUM] http: stricter processing of the CONNECT method
18259 - [BUG] config: reset check request to avoid double free when switching to ssl/sql
18260 - [MINOR] config: fix too large ssl-hello-check message.
18261 - [BUG] fix error response in case of server error
18262
Willy Tarreau2eba6aa2010-01-25 23:28:05 +0100182632010/01/25 : 1.4-dev8
18264 - [CLEANUP] Keep in sync "defaults" support between documentation and code
18265 - [MEDIUM] http: add support for Proxy-Connection header
18266 - [CRITICAL] buffers: buffer_insert_line2 must not change the ->w entry
18267 - [MINOR] http: remove a copy-paste typo in transaction cleaning
18268 - [BUG] http: trim any excess buffer data when recycling a connection
18269
Willy Tarreau6939b552010-01-25 01:54:37 +0100182702010/01/25 : 1.4-dev7
18271 - [BUG] appsession: possible memory leak in case of out of memory condition
18272 - [MINOR] config: don't accept 'appsession' in defaults section
18273 - [MINOR] Add function to parse a size in configuration
18274 - [MEDIUM] Add stick table (persistence) management functions and types
18275 - [MEDIUM] Add pattern fetch management types and functions
18276 - [MEDIUM] Add src dst and dport pattern fetches.
18277 - [MEDIUM] Add stick table configuration and init.
18278 - [MEDIUM] Add stick and store rules analysers.
18279 - [MINOR] add option "mysql-check" to use MySQL health checks
18280 - [BUG] health checks: fix requeued message
18281 - [OPTIM] remove SSP_O_VIA and SSP_O_STATUS
18282 - [BUG] checks: fix newline termination
18283 - [MINOR] acl: add fe_id/so_id to match frontend's and socket's id
18284 - [BUG] appsession's sessid must be reset at end of transaction
18285 - [BUILD] appsession did not build anymore under gcc-2.95
18286 - [BUG] server redirection used an uninitialized string.
18287 - [MEDIUM] http: fix handling of message pointers
18288 - [MINOR] http: fix double slash prefix with server redirect
18289 - [MINOR] http redirect: add the ability to append a '/' to the URL
18290 - [BUG] stream_interface: fix retnclose and remove cond_close
18291 - [MINOR] http redirect: don't explicitly state keep-alive on 1.1
18292 - [MINOR] http: move appsession 'sessid' from session to http_txn
18293 - [OPTIM] reorder http_txn to optimize cache lines placement
18294 - [MINOR] http: differentiate waiting for new request and waiting for a complete requst
18295 - [MINOR] http: add a separate "http-keep-alive" timeout
18296 - [MINOR] config: remove undocumented and buggy 'timeout appsession'
18297 - [DOC] fix various too large lines
18298 - [DOC] remove several trailing spaces
18299 - [DOC] add the doc about stickiness
18300 - [BUILD] remove a warning in standard.h on AIX
18301 - [BUG] checks: chars are unsigned on AIX, check was always true
18302 - [CLEANUP] stream_sock: MSG_NOSIGNAL is only for send(), not recv()
18303 - [BUG] check: we must not check for error before reading a response
18304 - [BUG] buffers: remove remains of wrong obsolete length check
18305 - [OPTIM] stream_sock: don't shutdown(write) when the socket is in error
18306 - [BUG] http: don't count req errors on client resets or t/o during keep-alive
18307 - [MEDIUM] http: don't switch to tunnel mode upon close
18308 - [DOC] add documentation about connection header processing
18309 - [MINOR] http: add http_remove_header2() to remove a header value.
18310 - [MINOR] tools: add a "word_match()" function to match words and ignore spaces
18311 - [MAJOR] http: rework request Connection header handling
18312 - [MAJOR] http: rework response Connection header handling
18313 - [MINOR] add the ability to force kernel socket buffer size.
18314 - [BUG] http_server_error() must not purge a previous pending response
18315 - [OPTIM] http: don't delay response if next request is incomplete
18316 - [MINOR] add the "force-persist" statement to force persistence on down servers
18317 - [MINOR] http: logs must report persistent connections to down servers
18318 - [BUG] buffer_replace2 must never change the ->w entry
18319
Willy Tarreau11f8f542010-01-08 07:49:44 +0100183202010/01/08 : 1.4-dev6
18321 - [BUILD] warning in stream_interface.h
18322 - [BUILD] warning ultoa_r returns char *
18323 - [MINOR] hana: only report stats if it is enabled
18324 - [MINOR] stats: add "a link" & "a href" for sockets
18325 - [MINOR]: stats: add show-legends to report additional informations
18326 - [MEDIUM] default-server support
18327 - [BUG]: add 'observer', 'on-error', 'error-limit' to supported options list
18328 - [MINOR] stats: add href to tracked server
18329 - [BUG] stats: show UP/DOWN status also in tracking servers
18330 - [DOC] Restore ability to search a keyword at the beginning of a line
18331 - [BUG] stats: cookie should be reported under backend not under proxy
18332 - [BUG] cfgparser/stats: fix error message
18333 - [BUG] http: disable auto-closing during chunk analysis
18334 - [BUG] http: fix hopefully last closing issue on data forwarding
18335 - [DEBUG] add an http_silent_debug function to debug HTTP states
18336 - [MAJOR] http: fix again the forward analysers
18337 - [BUG] http_process_res_common() must not skip the forward analyser
18338 - [BUG] http: some possible missed close remain in the forward chain
18339 - [BUG] http: redirect needed to be updated after recent changes
18340 - [BUG] http: don't set no-linger on response in case of forced close
18341 - [MEDIUM] http: restore the original behaviour of option httpclose
18342 - [TESTS] add a file to test various connection modes
18343 - [BUG] http: check options before the connection header
18344 - [MAJOR] session: fix the order by which the analysers are run
18345 - [MEDIUM] session: also consider request analysers added during response
18346 - [MEDIUM] http: make safer use of the DONT_READ and AUTO_CLOSE flags
18347 - [BUG] http: memory leak with captures when using keep-alive
18348 - [BUG] http: fix for capture memory leak was incorrect
18349 - [MINOR] http redirect: use proper call to return last response
18350 - [MEDIUM] http: wait for some flush of the response buffer before a new request
18351 - [MEDIUM] session: limit the number of analyser loops
18352
Willy Tarreau1f445892010-01-03 23:23:36 +0100183532010/01/03 : 1.4-dev5
18354 - [MINOR] server tracking: don't care about the tracked server's mode
18355 - [MEDIUM] appsession: add "len", "prefix" and "mode" options
18356 - [MEDIUM] appsession: add the "request-learn" option
18357 - [BUG] Configuration parser bug when escaping characters
18358 - [MINOR] CSS & HTML fun
18359 - [MINOR] Collect & provide http response codes received from servers
18360 - [BUG] Fix silly typo: hspr_other -> hrsp_other
18361 - [MINOR] Add "a name" to stats page
18362 - [MINOR] add additional "a href"s to stats page
18363 - [MINOR] Collect & provide http response codes for frontends, fix backends
18364 - [DOC] some small spell fixes and unifications
18365 - [MEDIUM] Decrease server health based on http responses / events, version 3
18366 - [BUG] format '%d' expects type 'int', but argument 5 has type 'long int'
18367 - [BUG] config: fix erroneous check on cookie domain names, again
18368 - [BUG] Healthchecks: get a proper error code if connection cannot be completed immediately
18369 - [DOC] trivial fix for man page
18370 - [MINOR] config: report all supported options for the "bind" keyword
18371 - [MINOR] tcp: add support for the defer_accept bind option
18372 - [MINOR] unix socket: report the socket path in case of bind error
18373 - [CONTRIB] halog: support searching by response time
18374 - [DOC] add a reminder about obsolete documents
18375 - [DOC] point to 1.4 doc, not 1.3
18376 - [DOC] option tcp-smart-connect was missing from index
18377 - [MINOR] http: detect connection: close earlier
18378 - [CLEANUP] sepoll: clean up the fd_clr/fd_set functions
18379 - [OPTIM] move some rarely used fields out of fdtab
18380 - [MEDIUM] fd: merge fd_list into fdtab
18381 - [MAJOR] buffer: flag BF_DONT_READ to disable reads when not required
18382 - [MINOR] http: add new transaction flags for keep-alive and content-length
18383 - [MEDIUM] http request: parse connection, content-length and transfer-encoding
18384 - [MINOR] http request: update the TX_SRV_CONN_KA flag on rewrite
18385 - [MINOR] http request: simplify the test of no-data
18386 - [MEDIUM] http request: simplify POST length detection
18387 - [MEDIUM] http request: make use of pre-parsed transfer-encoding header
18388 - [MAJOR] http: create the analyser which waits for a response
18389 - [MINOR] http: pre-set the persistent flags in the transaction
18390 - [MEDIUM] http response: check body length and set transaction flags
18391 - [MINOR] http response: update the TX_CLI_CONN_KA flag on rewrite
18392 - [MINOR] http: remove the last call to stream_int_return
18393 - [IMPORT] import ebtree v5.0 into directory ebtree/
18394 - [MEDIUM] build: switch ebtree users to use new ebtree version
18395 - [CLEANUP] ebtree: remove old unused files
18396 - [BUG] definitely fix regparm issues between haproxy core and ebtree
18397 - [CLEANUP] ebtree: cast to char * to get rid of gcc warning
18398 - [BUILD] missing #ifndef in ebmbtree.h
18399 - [BUILD] missing #ifndef in ebsttree.h
18400 - [MINOR] tools: add hex2i() function to convert hex char to int
18401 - [MINOR] http: create new MSG_BODY sub-states
18402 - [BUG] stream_sock: BUF_INFINITE_FORWARD broke splice on 64-bit platforms
18403 - [DOC] option is "defer-accept", not "defer_accept"
18404 - [MINOR] http: keep pointer to beginning of data
18405 - [BUG] x-original-to: name was not set in default instance
18406 - [MINOR] http: detect tunnel mode and set it in the session
18407 - [BUG] config: fix error message when config file is not found
18408 - [BUG] config: fix wrong handling of too large argument count
18409 - [BUG] config: disable 'option httplog' on TCP proxies
18410 - [BUG] config: fix erroneous check on cookie domain names
18411 - [BUG] config: cookie domain was ignored in defaults sections
18412 - [MINOR] config: support passing multiple "domain" statements to cookies
18413 - [MINOR] ebtree: add functions to lookup non-null terminated strings
18414 - [MINOR] config: don't report error on all subsequent files on failure
18415 - [BUG] second fix for the printf format warning
18416 - [BUG] check_post: limit analysis to the buffer length
18417 - [MEDIUM] http: process request body in a specific analyser
18418 - [MEDIUM] backend: remove HTTP POST parsing from get_server_ph_post()
18419 - [MAJOR] http: completely process the "connection" header
18420 - [MINOR] http: only consider chunk encoding with HTTP/1.1
18421 - [MAJOR] buffers: automatically compute the maximum buffer length
18422 - [MINOR] http: move the http transaction init/cleanup code to proto_http
18423 - [MINOR] http: move 1xx handling earlier to eliminate a lot of ifs
18424 - [MINOR] http: introduce a new synchronisation state : HTTP_MSG_DONE
18425 - [MEDIUM] http: rework chunk-size parser
18426 - [MEDIUM] http: add a new transaction flags indicating if we know the transfer length
18427 - [MINOR] buffers: add buffer_ignore() to skip some bytes
18428 - [BUG] http: offsets are relative to the buffer, not to ->som
18429 - [MEDIUM] http: automatically re-aling request buffer
18430 - [BUG] http: body parsing must consider the start of message
18431 - [MINOR] new function stream_int_cond_close()
18432 - [MAJOR] http: implement body parser
18433 - [BUG] http: typos on several unlikely() around header insertion
18434 - [BUG] stream_sock: wrong max computation on recv
18435 - [MEDIUM] http: rework the buffer alignment logic
18436 - [BUG] buffers: wrong size calculation for displaced data
18437 - [MINOR] stream_sock: prepare for closing when all pending data are sent
18438 - [MEDIUM] http: add two more states for the closing period
18439 - [MEDIUM] http: properly handle "option forceclose"
18440 - [MINOR] stream_sock: add SI_FL_NOLINGER for faster close
18441 - [MEDIUM] http: make forceclose use SI_FL_NOLINGER
18442 - [MEDIUM] session: set SI_FL_NOLINGER when aborting on write timeouts
18443 - [MEDIUM] http: add some SI_FL_NOLINGER around server errors
18444 - [MINOR] config: option forceclose is valid in frontends too
18445 - [BUILD] halog: insufficient include path in makefile
18446 - [MEDIUM] http: make the analyser not rely on msg being initialized anymore
18447 - [MEDIUM] http: make the parsers able to wait for a buffer flush
18448 - [MAJOR] http: add support for option http-server-close
18449 - [BUG] http: ensure we abort data transfer on write error
18450 - [BUG] last fix was overzealous and disabled server-close
18451 - [BUG] http: fix erroneous trailers size computation
18452 - [MINOR] stream_sock: enable MSG_MORE when forwarding finite amount of data
18453 - [OPTIM] http: set MSG_MORE on response when a pipelined request is pending
18454 - [BUG] http: redirects were broken by chunk changes
18455 - [BUG] http: the request URI pointer is relative to the buffer
18456 - [OPTIM] http: don't immediately enable reading on request
18457 - [MINOR] http: move redirect messages to HTTP/1.1 with a content-length
18458 - [BUG] http: take care of errors, timeouts and aborts during the data phase
18459 - [MINOR] http: don't wait for sending requests to the server
18460 - [MINOR] http: make the conditional redirect support keep-alive
18461 - [BUG] http: fix cookie parser to support spaces and commas in values
18462 - [MINOR] config: some options were missing for "redirect"
18463 - [MINOR] redirect: add support for unconditional rules
18464 - [MINOR] config: centralize proxy struct initialization
18465 - [MEDIUM] config: remove the limitation of 10 reqadd/rspadd statements
18466 - [MEDIUM] config: remove the limitation of 10 config files
18467 - [CLEANUP] http: remove a remaining impossible condition
18468 - [OPTIM] http: optimize a bit the construct of the forward loops
18469
Willy Tarreauc82a9e52009-10-12 06:40:53 +0200184702009/10/12 : 1.4-dev4
18471 - [DOC] add missing rate_lim and rate_max
18472 - [MAJOR] struct chunk rework
18473 - [MEDIUM] Health check reporting code rework + health logging, v3
18474 - [BUG] check if rise/fall has an argument and it is > 0
18475 - [MINOR] health checks logging unification
18476 - [MINOR] add "description", "node" and show-node"/"show-desc", remove "node-name", v2
18477 - [MINOR] Allow dots in show-node & add "white-space: nowrap" in th.pxname.
18478 - [DOC] Add information about http://haproxy.1wt.eu/contrib.html
18479 - [MINOR] Introduce include/types/counters.h
18480 - [CLEANUP] Move counters to dedicated structures
18481 - [MINOR] Add "clear counters" to clear statistics counters
18482 - [MEDIUM] Collect & provide separate statistics for sockets, v2
18483 - [BUG] Fix NULL pointer dereference in stats_check_uri_auth(), v2
18484 - [MINOR] acl: don't report valid acls as potential mistakes
18485 - [MINOR] Add cut_crlf(), ltrim(), rtrim() and alltrim()
18486 - [MINOR] Add chunk_htmlencode and chunk_asciiencode
18487 - [MINOR] Capture & display more data from health checks, v2
18488 - [BUG] task.c: don't assing last_timer to node-less entries
18489 - [BUG] http stats: large outputs sometimes got some parts chopped off
18490 - [MINOR] backend: export some functions to recount servers
18491 - [MINOR] backend: uninline some LB functions
18492 - [MINOR] include time.h from freq_ctr.h as is uses "now".
18493 - [CLEANUP] backend: move LB algos to individual files
18494 - [MINOR] lb_map: reorder code in order to ease integration of new hash functions
18495 - [CLEANUP] proxy: move last lb-specific bits to their respective files
18496 - [MINOR] backend: separate declarations of LB algos from their lookup method
18497 - [MINOR] backend: reorganize the LB algorithm selection
18498 - [MEDIUM] backend: introduce the "static-rr" LB algorithm
18499 - [MINOR] report list of supported pollers with -vv
18500 - [DOC] log-health-checks is an option, not a directive
18501 - [MEDIUM] new option "independant-streams" to stop updating read timeout on writes
18502 - [BUG] stats: don't call buffer_shutw(), but ->shutw() instead
18503 - [MINOR] stats: strip CR and LF from the input command line
18504 - [BUG] don't refresh timeouts late after detected activity
18505 - [MINOR] stats_dump_errors_to_buffer: use buffer_feed_chunk()
18506 - [MINOR] stats_dump_sess_to_buffer: use buffer_feed_chunk()
18507 - [MINOR] stats: make stats_dump_raw_to_buffer() use buffer_feed_chunk
18508 - [MEDIUM] stats: don't use s->ana_state anymore
18509 - [MINOR] remove now obsolete ana_state from the session struct
18510 - [MEDIUM] stats: make HTTP stats use an I/O handler
18511 - [MEDIUM] stream_int: adjust WAIT_ROOM handling
18512 - [BUG] config: look for ID conflicts in all sockets, not only last ones.
18513 - [MINOR] config: reference file and line with any listener/proxy/server declaration
18514 - [MINOR] config: report places of duplicate names or IDs
18515 - [MINOR] config: add pointer to file name in block/redirect/use_backend/monitor rules
18516 - [MINOR] tools: add a new get_next_id() function
18517 - [MEDIUM] config: automatically find unused IDs for proxies, servers and listeners
18518 - [OPTIM] counters: move some max numbers to the counters struct
18519 - [BUG] counters: fix segfault on missing counters for a listener
18520 - [MEDIUM] backend: implement consistent hashing variation
18521 - [MINOR] acl: add fe_conn, be_conn, queue, avg_queue
18522 - [MINOR] stats: use 'clear counters all' to clear all values
18523 - [MEDIUM] add access restrictions to the stats socket
18524 - [MINOR] buffers: add buffer_feed2() and make buffer_feed() measure string length
18525 - [MINOR] proxy: provide function to retrieve backend/server pointers
18526 - [MINOR] add the "initial weight" to the server struct.
18527 - [MEDIUM] stats: add the "get weight" command to report a server's weight
18528 - [MEDIUM] stats: add the "set weight" command
18529 - [BUILD] add a 'make tags' target
18530 - [MINOR] stats: add support for numeric IDs in set weight/get weight
18531 - [MINOR] stats: use a dedicated state to output static data
18532 - [OPTIM] stats: check free space before trying to print
18533
Willy Tarreau9f389e02009-09-24 00:12:50 +0200185342009/09/24 : 1.4-dev3
18535 - [BUILD] compilation of haproxy-1.4-dev2 on FreeBSD
18536 - [MEDIUM] Collect & show information about last health check, v3
18537 - [MINOR] export the hostname variable so that all the code can access it
18538 - [MINOR] stats: add a new node-name setting
18539 - [MEDIUM] remove old experimental tcpsplice option
18540 - [BUILD] fix build for systems without SOL_TCP
18541 - [MEDIUM] move connection establishment from backend to the SI.
18542 - [MEDIUM] make the global stats socket part of a frontend
18543 - [MEDIUM] session: account per-listener connections
18544 - [MINOR] session: switch to established state if no connect function
18545 - [MEDIUM] make the unix stats sockets use the generic session handler
18546 - [CLEANUP] unix: remove uxst_process_session()
18547 - [CLEANUP] move remaining stats sockets code to dumpstats
18548 - [MINOR] move the initial task's nice value to the listener
18549 - [MINOR] cleanup set_session_backend by using pre-computed analysers
18550 - [MINOR] set s->srv_error according to the analysers
18551 - [MEDIUM] set rep->analysers from fe and be analysers
18552 - [MEDIUM] replace BUFSIZE with buf->size in computations
18553 - [MEDIUM] make it possible to change the buffer size in the configuration
18554 - [MEDIUM] report error on buffer writes larger than buffer size
18555 - [MEDIUM] stream_interface: add and use ->update function to resync
18556 - [CLEANUP] remove ifdef MSG_NOSIGNAL and define it instead
18557 - [MEDIUM] remove TCP_CORK and make use of MSG_MORE instead
18558 - [BUG] tarpit did not work anymore
18559 - [MINOR] acl: add support for hdr_ip to match IP addresses in headers
18560 - [MAJOR] buffers: fix misuse of the BF_SHUTW_NOW flag
18561 - [MINOR] buffers: provide more functions to handle buffer data
18562 - [MEDIUM] buffers: provide new buffer_feed*() function
18563 - [MINOR] buffers: add peekchar and peekline functions for stream interfaces
18564 - [MINOR] buffers: provide buffer_si_putchar() to send a char from a stream interface
18565 - [BUG] buffer_forward() would not correctly consider data already scheduled
18566 - [MINOR] buffers: add buffer_cut_tail() to cut only unsent data
18567 - [MEDIUM] stream_interface: make use of buffer_cut_tail() to report errors
18568 - [MAJOR] http: add support for HTTP 1xx informational responses
18569 - [MINOR] buffers: inline buffer_si_putchar()
18570 - [MAJOR] buffers: split BF_WRITE_ENA into BF_AUTO_CONNECT and BF_AUTO_CLOSE
18571 - [MAJOR] buffers: fix the BF_EMPTY flag's meaning
18572 - [BUG] stream_interface: SI_ST_CLO must have buffers SHUT
18573 - [MINOR] stream_sock: don't set SI_FL_WAIT_DATA if BF_SHUTW_NOW is set
18574 - [MEDIUM] add support for infinite forwarding
18575 - [BUILD] stream_interface: fix conflicting declaration
18576 - [BUG] buffers: buffer_forward() must not always clear BF_OUT_EMPTY
18577 - [BUG] variable buffer size ignored at initialization time
18578 - [MINOR] ensure that buffer_feed() and buffer_skip() set BF_*_PARTIAL
18579 - [BUG] fix buffer_skip() and buffer_si_getline() to correctly handle wrap-arounds
18580 - [MINOR] stream_interface: add SI_FL_DONT_WAKE flag
18581 - [MINOR] stream_interface: add iohandler callback
18582 - [MINOR] stream_interface: add functions to support running as internal/external tasks
18583 - [MEDIUM] session: call iohandler for embedded tasks (applets)
18584 - [MINOR] add a ->private member to the stream_interface
18585 - [MEDIUM] stats: prepare the connection for closing before dumping
18586 - [MEDIUM] stats: replace the stats socket analyser with an SI applet
18587
Willy Tarreau68dcd252009-08-09 22:57:09 +0200185882009/08/09 : 1.4-dev2
18589 - [BUG] task: fix possible crash when some timeouts are not configured
18590 - [BUG] log: option tcplog would log to global if no logger was defined
18591
Willy Tarreaub03d2982009-07-29 22:38:32 +0200185922009/07/29 : 1.4-dev1
18593 - [MINOR] acl: add support for matching of RDP cookies
18594 - [MEDIUM] add support for RDP cookie load-balancing
18595 - [MEDIUM] add support for RDP cookie persistence
18596 - [MINOR] add a new CLF log format
18597 - [MINOR] startup: don't imply -q with -D
18598 - [BUG] ensure that we correctly re-start old process in case of error
18599 - [MEDIUM] add support for binding to source port ranges during connect
18600 - [MINOR] config: track "no option"/"option" changes
18601 - [MINOR] config: support resetting options do default values
18602 - [MEDIUM] implement option tcp-smart-accept at the frontend
18603 - [MEDIUM] stream_sock: implement tcp-cork for use during shutdowns on Linux
18604 - [MEDIUM] implement tcp-smart-connect option at the backend
18605 - [MEDIUM] add support for TCP MSS adjustment for listeners
18606 - [MEDIUM] support setting a server weight to zero
18607 - [MINOR] make DEFAULT_MAXCONN user-configurable at build time
18608 - [MAJOR] session: don't clear buffer status flags anymore
18609 - [MAJOR] session: only check for timeouts when they have just occurred.
18610 - [MAJOR] session: simplify buffer error handling
18611 - [MEDIUM] config: split parser and checker in two functions
18612 - [MEDIUM] config: support loading multiple configuration files
18613 - [MEDIUM] stream_sock: don't close prematurely when nolinger is set
18614 - [MEDIUM] session: rework buffer analysis to permit permanent analysers
18615 - [MEDIUM] splice: set the capability on each stream_interface
18616 - [BUG] http: redirect rules were processed too early
18617 - [CLEANUP] remove unused DEBUG_PARSE_NO_SPEEDUP define
18618 - [MEDIUM] http: split request waiter from request processor
18619 - [MEDIUM] session: tell analysers what bit they were called for
18620 - [MAJOR] http: complete splitting of the remaining stages
18621 - [MINOR] report in the proxies the requirements for ACLs
18622 - [MINOR] http: rely on proxy->acl_requires to allocate hdr_idx
18623 - [MINOR] acl: add HTTP protocol detection (req_proto_http)
18624 - [MINOR] prepare callers of session_set_backend to handle errors
18625 - [BUG] default ACLs did not properly set the ->requires flag
18626 - [MEDIUM] allow a TCP frontend to switch to an HTTP backend
18627 - [MINOR] ensure we can jump from swiching rules to http without data
18628 - [MINOR] http: take http request timeout from the backend
18629 - [MINOR] allow TCP inspection rules to make use of HTTP ACLs
18630 - [BUILD] report commit date and not author's date as build date
18631 - [MINOR] acl: don't complain anymore when using L7 acls in TCP
18632 - [BUG] stream_sock: always shutdown(SHUT_WR) before closing
18633 - [BUG] stream_sock: don't stop reading when the poller reports an error
18634 - [BUG] config: tcp-request content only accepts "if" or "unless"
18635 - [BUG] task: fix possible timer drift after update
18636 - [MINOR] apply tcp-smart-connect option for the checks too
18637 - [MINOR] stats: better displaying in MSIE
18638 - [MINOR] config: improve error reporting in global section
18639 - [MINOR] config: improve error reporting in listen sections
18640 - [MINOR] config: the "capture" keyword is not allowed in backends
18641 - [MINOR] config: improve error reporting when checking configuration
18642 - [BUILD] fix a minor build warning on AIX
18643 - [BUILD] use "git cmd" instead of "git-cmd"
18644 - [CLEANUP] report 2009 not 2008 in the copyright banner.
18645 - [MINOR] print usage on the stats sockets upon invalid commands
18646 - [MINOR] acl: detect and report potential mistakes in ACLs
18647 - [BUILD] fix incorrect printf arg count with tcp_splice
18648 - [BUG] fix random pauses on last segment of a series
18649 - [BUILD] add support for build under Cygwin
18650
Willy Tarreau79158882009-06-09 11:59:08 +0200186512009/06/09 : 1.4-dev0
18652 - exact copy of 1.3.18
18653
Willy Tarreaubeb05ae2009-05-10 20:27:47 +0200186542009/05/10 : 1.3.18
18655 - [MEDIUM] add support for "balance hdr(name)"
18656 - [CLEANUP] give a little bit more information in error message
18657 - [MINOR] add X-Original-To: header
18658 - [BUG] x-original-to: fix missing initialization to default value
18659 - [BUILD] spec file: fix broken pipe during rpmbuild and add man file
18660 - [MINOR] improve reporting of misplaced acl/reqxxx rules
18661 - [MEDIUM] http: add options to ignore invalid header names
18662 - [MEDIUM] http: capture invalid requests/responses even if accepted
18663 - [BUILD] add format(printf) to printf-like functions
18664 - [MINOR] fix several printf formats and missing arguments
18665 - [BUG] stats: total and lbtot are unsigned
18666 - [MINOR] fix a few remaining printf-like formats on 64-bit platforms
18667 - [CLEANUP] remove unused make option from haproxy.spec
18668 - [BUILD] make it possible to pass alternative arch at build time
18669 - [MINOR] switch all stat counters to 64-bit
18670 - [MEDIUM] ensure we don't recursively call pool_gc2()
18671 - [CRITICAL] uninitialized response field can sometimes cause crashes
18672 - [BUG] fix wrong pointer arithmetics in HTTP message captures
18673 - [MINOR] rhel init script : support the reload operation
18674 - [MINOR] add basic signal handling functions
18675 - [BUILD] add signal.o to all makefiles
18676 - [MEDIUM] call signal_process_queue from run_poll_loop
18677 - [MEDIUM] pollers: don't wait if a signal is pending
18678 - [MEDIUM] convert all signals to asynchronous signals
18679 - [BUG] O(1) pollers should check their FD before closing it
18680 - [MINOR] don't close stdio fds twice
18681 - [MINOR] add options dontlog-normal and log-separate-errors
18682 - [DOC] minor fixes and rearrangements
18683 - [BUG] fix parser crash on unconditional tcp content rules
18684 - [DOC] rearrange the configuration manual and add a summary
18685 - [MINOR] standard: provide a new 'my_strndup' function
18686 - [MINOR] implement per-logger log level limitation
18687 - [MINOR] compute the max of sessions/s on fe/be/srv
18688 - [MINOR] stats: report max sessions/s and limit in CSV export
18689 - [MINOR] stats: report max sessions/s and limit in HTML stats
18690 - [MINOR] stats/html: use the arial font before helvetica
18691
Willy Tarreauf459b422009-03-29 15:26:57 +0200186922009/03/29 : 1.3.17
18693 - Update specfile to build for v2.6 kernel.
18694 - [BUG] reset the stream_interface connect timeout upon connect or error
18695 - [BUG] reject unix accepts when connection limit is reached
18696 - [MINOR] show sess: report number of calls to each task
18697 - [BUG] don't call epoll_ctl() on closed sockets
18698 - [BUG] stream_sock: disable I/O on fds reporting an error
18699 - [MINOR] sepoll: don't count two events on the same FD.
18700 - [MINOR] show sess: report a lot more information about sessions
18701 - [BUG] stream_sock: check for shut{r,w} before refreshing some timeouts
18702 - [BUG] don't set an expiration date directly from now_ms
18703 - [MINOR] implement ulltoh() to write HTML-formatted numbers
18704 - [MINOR] stats/html: group digits by 3 to clarify numbers
18705 - [BUILD] remove haproxy-small.spec
18706 - [BUILD] makefile: remove unused references to linux24eold and EPOLL_CTL_WORKAROUND
18707
Willy Tarreau8019ffa2009-03-22 23:46:12 +0100187082009/03/22 : 1.3.16
18709 - [BUILD] Fixed Makefile for linking pcre
18710 - [CONTRIB] selinux policy for haproxy
18711 - [MINOR] show errors: encode backslash as well as non-ascii characters
18712 - [MINOR] cfgparse: some cleanups in the consistency checks
18713 - [MINOR] cfgparse: set backends to "balance roundrobin" by default
18714 - [MINOR] tcp-inspect: permit the use of no-delay inspection
18715 - [MEDIUM] reverse internal proxy declaration order to match configuration
18716 - [CLEANUP] config: catch and report some possibly wrong rule ordering
18717 - [BUG] connect timeout is in the stream interface, not the buffer
18718 - [BUG] session: errors were not reported in termination flags in TCP mode
18719 - [MINOR] tcp_request: let the caller take care of errors and timeouts
18720 - [CLEANUP] http: remove some commented out obsolete code in process_response
18721 - [MINOR] update ebtree to version 4.1
18722 - [MEDIUM] scheduler: get rid of the 4 trees thanks and use ebtree v4.1
18723 - [BUG] sched: don't leave 3 lasts tasks unprocessed when niced tasks are present
18724 - [BUG] scheduler: fix improper handling of duplicates __task_queue()
18725 - [MINOR] sched: permit a task to stay up between calls
18726 - [MINOR] task: keep a task count and clean up task creators
18727 - [MINOR] stats: report number of tasks (active and running)
18728 - [BUG] server check intervals must not be null
18729 - [OPTIM] stream_sock: don't retry to read after a large read
18730 - [OPTIM] buffer: new BF_READ_DONTWAIT flag reduces EAGAIN rates
18731 - [MEDIUM] session: don't resync FSMs on non-interesting changes
18732 - [BUG] check for global.maxconn before doing accept()
18733 - [OPTIM] sepoll: do not re-check whole list upon accepts
18734
Willy Tarreau8185ced2009-03-09 22:45:53 +0100187352009/03/09 : 1.3.16-rc2
18736 - [BUG] stream_sock: write timeout must be updated when forwarding !
18737
Willy Tarreauff63b432009-03-09 01:03:42 +0100187382009/03/09 : 1.3.16-rc1
18739 - appsessions: cleanup DEBUG_HASH and initialize request_counter
18740 - [MINOR] acl: add new keyword "connslots"
18741 - [MINOR] cfgparse: fix off-by 2 in error message size
18742 - [BUILD] fix build with gcc 4.3
18743 - [BUILD] fix MANDIR default location to match documentation
18744 - [TESTS] add a debug patch to help trigger the stats bug
18745 - [BUG] Flush buffers also where there are exactly 0 bytes left
18746 - [MINOR] Allow to specify a domain for a cookie
18747 - [BUG/CLEANUP] cookiedomain -> cookie_domain rename + free(p->cookie_domain)
18748 - [MEDIUM] Fix memory freeing at exit
18749 - [MEDIUM] Fix memory freeing at exit, part 2
18750 - [BUG] Fix listen & more of 2 couples <ip>:<port>
18751 - [DOC] remove buggy comment for use_backend
18752 - [CRITICAL] fix server state tracking: it was O(n!) instead of O(n)
18753 - [MEDIUM] add support for URI hash depth and length limits
18754 - [MINOR] permit renaming of x-forwarded-for header
18755 - [BUILD] fix Makefile.bsd and Makefile.osx for stream_interface
18756 - [BUILD] Haproxy won't compile if DEBUG_FULL is defined
18757 - [MEDIUM] upgrade to ebtree v4.0
18758 - [DOC] update the README file with new build options
18759 - [MEDIUM] reduce risk of event starvation in ev_sepoll
18760 - [MEDIUM] detect streaming buffers and tag them as such
18761 - [MEDIUM] add support for conditional HTTP redirection
18762 - [BUILD] make install should depend on haproxy not "all"
18763 - [DEBUG] add a TRACE macro to facilitate runtime data extraction
18764 - [BUG] event pollers must not wait if a task exists in the run queue
18765 - [BUG] queue management: wake oldest request in queues
18766 - [BUG] log: reported queue position was offed-by-one
18767 - [BUG] fix the dequeuing logic to ensure that all requests get served
18768 - [DOC] documentation for the "retries" parameter was missing.
18769 - [MEDIUM] implement a monotonic internal clock
18770 - [MEDIUM] further improve monotonic clock by check forward jumps
18771 - [OPTIM] add branch prediction hints in list manipulations
18772 - [MAJOR] replace ultree with ebtree in wait-queues
18773 - [BUG] we could segfault during exit while freeing uri_auths
18774 - [BUG] wqueue: perform proper timeout comparisons with wrapping values
18775 - [MINOR] introduce now_ms, the current date in milliseconds
18776 - [BUG] disable buffer read timeout when reading stats
18777 - [MEDIUM] rework the wait queue mechanism
18778 - [BUILD] change declaration of base64tab to fix build with Intel C++
18779 - [OPTIM] shrink wake_expired_tasks() by using task_wakeup()
18780 - [MAJOR] use an ebtree instead of a list for the run queue
18781 - [MEDIUM] introduce task->nice and boot access to statistics
18782 - [OPTIM] task_queue: assume most consecutive timers are equal
18783 - [BUILD] silent a warning in unlikely() with gcc 4.x
18784 - [MAJOR] convert all expiration timers from timeval to ticks
18785 - [BUG] use_backend would not correctly consider "unless"
18786 - [TESTS] added test-acl.cfg to test some ACL combinations
18787 - [MEDIUM] add support for configuration keyword registration
18788 - [MEDIUM] modularize the global "stats" keyword configuration parser
18789 - [MINOR] cfgparse: add support for warnings in external functions
18790 - [MEDIUM] modularize the "timeout" keyword configuration parser
18791 - [MAJOR] implement tcp request content inspection
18792 - [MINOR] acl: add a new parsing function: parse_dotted_ver
18793 - [MINOR] acl: add req_ssl_ver in TCP, to match an SSL version
18794 - [CLEANUP] remove unused include/types/client.h
18795 - [CLEANUP] remove many #include <types/xxx> from C files
18796 - [CLEANUP] remove dependency on obsolete INTBITS macro
18797 - [DOC] document the new "tcp-request" keyword and associated ACLs
18798 - [MINOR] acl: add REQ_CONTENT to the list of default acls
18799 - [MEDIUM] acl: permit fetch() functions to set the result themselves
18800 - [MEDIUM] acl: get rid of dummy values in always_true/always_false
18801 - [MINOR] acl: add the "wait_end" acl verb
18802 - [MEDIUM] acl: enforce ACL type checking
18803 - [MEDIUM] acl: set types on all currently known ACL verbs
18804 - [MEDIUM] acl: when possible, report the name and requirements of ACLs in warnings
18805 - [CLEANUP] remove 65 useless NULL checks before free
18806 - [MEDIUM] memory: update pool_free2() to support NULL pointers
18807 - [MEDIUM] buffers: ensure buffer_shut* are properly called upon shutdowns
18808 - [MEDIUM] process_srv: rely on buffer flags for client shutdown
18809 - [MEDIUM] process_srv: don't rely at all on client state
18810 - [MEDIUM] process_cli: don't rely at all on server state
18811 - [BUG] fix segfault with url_param + check_post
18812 - [BUG] server timeout was not considered in some circumstances
18813 - [BUG] client timeout incorrectly rearmed while waiting for server
18814 - [MAJOR] kill CL_STINSPECT and CL_STHEADERS (step 1)
18815 - [MAJOR] get rid of SV_STANALYZE (step 2)
18816 - [MEDIUM] simplify and centralize request timeout cancellation and request forwarding
18817 - [MAJOR] completely separate HTTP and TCP states on the request path
18818 - [BUG] fix recently introduced loop when client closes early
18819 - [MAJOR] get rid of the SV_STHEADERS state
18820 - [MAJOR] better separation of response processing and server state
18821 - [MAJOR] clearly separate HTTP response processing from TCP server state
18822 - [MEDIUM] remove unused references to {CL|SV}_STSHUT*
18823 - [MINOR] term_trace: add better instrumentations to trace the code
18824 - [BUG] ev_sepoll: closed file descriptors could persist in the spec list
18825 - [BUG] process_response must not enable the read FD
18826 - [BUG] buffers: remove BF_MAY_CONNECT and fix forwarding issue
18827 - [BUG] process_response: do not touch srv_state
18828 - [BUG] maintain_proxies must not disable backends
18829 - [CLEANUP] get rid of BF_SHUT*_PENDING
18830 - [MEDIUM] buffers: add BF_EMPTY and BF_FULL to remove dependency on req/rep->l
18831 - [MAJOR] process_session: rely only on buffer flags
18832 - [MEDIUM] use buffer->wex instead of buffer->cex for connect timeout
18833 - [MEDIUM] centralize buffer timeout checks at the top of process_session
18834 - [MINOR] ensure the termination flags are set by process_xxx
18835 - [MEDIUM] session: move the analysis bit field to the buffer
18836 - [OPTIM] process_cli/process_srv: reduce the number of tests
18837 - [BUG] regparm is broken on gcc < 3
18838 - [BUILD] fix warning in proto_tcp.c with gcc >= 4
18839 - [MEDIUM] merge inspect_exp and txn->exp into request buffer
18840 - [BUG] process_cli/process_srv: don't call shutdown when already done
18841 - [BUG] process_request: HTTP body analysis must return zero if missing data
18842 - [TESTS] test-fsm: 22 regression tests for state machines
18843 - [BUG] Fix empty X-Forwarded-For header name when set in defaults section
18844 - [BUG] fix harmless but wrong fd insertion sequence
18845 - [MEDIUM] make it possible for analysers to follow the whole session
18846 - [MAJOR] rework of the server FSM
18847 - [OPTIM] remove useless fd_set(read) upon shutdown(write)
18848 - [MEDIUM] massive cleanup of process_srv()
18849 - [MEDIUM] second level of code cleanup for process_srv_data
18850 - [MEDIUM] third cleanup and optimization of process_srv_data()
18851 - [MEDIUM] process_srv_data: ensure that we always correctly re-arm timeouts
18852 - [MEDIUM] stream_sock_process_data moved to stream_sock.c
18853 - [MAJOR] make the client side use stream_sock_process_data()
18854 - [MEDIUM] split stream_sock_process_data
18855 - [OPTIM] stream_sock_read must check for null-reads more often
18856 - [MINOR] only call flow analysers when their read side is connected.
18857 - [MEDIUM] reintroduce BF_HIJACK with produce_content
18858 - [MINOR] re-arrange buffer flags and rename some of them
18859 - [MINOR] do not check for BF_SHUTR when computing write timeout
18860 - [OPTIM] ev_sepoll: detect newly created FDs and check them once
18861 - [OPTIM] reduce the number of calls to task_wakeup()
18862 - [OPTIM] force inlining of large functions with gcc >= 3
18863 - [MEDIUM] indicate a reason for a task wakeup
18864 - [MINOR] change type of fdtab[]->owner to void*
18865 - [MAJOR] make stream sockets aware of the stream interface
18866 - [MEDIUM] stream interface: add the ->shutw method as well as in and out buffers
18867 - [MEDIUM] buffers: add BF_READ_ATTACHED and BF_ANA_TIMEOUT
18868 - [MEDIUM] process_session: make use of the new buffer flags
18869 - [CLEANUP] process_session: move debug outputs out of the critical loop
18870 - [MEDIUM] move QUEUE and TAR timers to stream interfaces
18871 - [OPTIM] add compiler hints in tick_is_expired()
18872 - [MINOR] add buffer_check_timeouts() to check what timeouts have fired.
18873 - [MEDIUM] use buffer_check_timeouts instead of stream_sock_check_timeouts()
18874 - [MINOR] add an expiration flag to the stream_sock_interface
18875 - [MAJOR] migrate the connection logic to stream interface
18876 - [MAJOR] add a connection error state to the stream_interface
18877 - [MEDIUM] add the SN_CURR_SESS flag to the session to track open sessions
18878 - [MEDIUM] continue layering cleanups.
18879 - [MEDIUM] stream_interface: added a DISconnected state between CON/EST and CLO
18880 - [MEDIUM] remove stream_sock_update_data()
18881 - [MINOR] maintain a global session list in order to ease debugging
18882 - [BUG] shutw must imply close during a connect
18883 - [MEDIUM] process shutw during connection attempt
18884 - [MEDIUM] make the stream interface control the SHUT{R,W} bits
18885 - [MAJOR] complete layer4/7 separation
18886 - [CLEANUP] move the session-related functions to session.c
18887 - [MINOR] call session->do_log() for logging
18888 - [MINOR] replace the ambiguous client_return function by stream_int_return
18889 - [MINOR] replace client_retnclose() with stream_int_retnclose()
18890 - [MINOR] replace srv_close_with_err() with http_server_error()
18891 - [MEDIUM] make the http server error function a pointer in the session
18892 - [CLEANUP] session.c: removed some migration left-overs in sess_establish()
18893 - [MINOR] stream_sock_data_finish() should not expose fd
18894 - [MEDIUM] extract TCP request processing from HTTP
18895 - [MEDIUM] extract the HTTP tarpit code from process_request().
18896 - [MEDIUM] move the HTTP request body analyser out of process_request().
18897 - [MEDIUM] rename process_request to http_process_request
18898 - [BUG] fix forgotten server session counter
18899 - [MINOR] declare process_session in session.h, not proto_http.h
18900 - [MEDIUM] first pass of lifting to proto_uxst.c:uxst_event_accept()
18901 - [MINOR] add an analyser code for UNIX stats request
18902 - [MINOR] pre-set analyser flags on the listener at registration time
18903 - [BUG] do not forward close from cons to prod with analysers
18904 - [MEDIUM] ensure that sock->shutw() also closes read for init states
18905 - [MINOR] add an analyser state in struct session
18906 - [MAJOR] make unix sockets work again with stats
18907 - [MEDIUM] remove cli_fd, srv_fd, cli_state and srv_state from the session
18908 - [MINOR] move the listener reference from fd to session
18909 - [MEDIUM] reference the current hijack function in the buffer itself
18910 - [MINOR] slightly rebalance stats_dump_{raw,http}
18911 - [MINOR] add a new back-reference type : struct bref
18912 - [MINOR] add back-references to sessions for later use by a dumper.
18913 - [MEDIUM] add support for "show sess" in unix stats socket
18914 - [BUG] do not release the connection slot during a retry
18915 - [BUG] dynamic connection throttling could return a max of zero conns
18916 - [BUG] do not try to pause backends during reload
18917 - [BUG] ensure that listeners from disabled proxies are correctly unbound.
18918 - [BUG] acl-related keywords are not allowed in defaults sections
18919 - [BUG] cookie capture is declared in the frontend but checked on the backend
18920 - [BUG] critical errors should be reported even in daemon mode
18921 - [MINOR] redirect: add support for the "drop-query" option
18922 - [MINOR] redirect: add support for "set-cookie" and "clear-cookie"
18923 - [MINOR] redirect: in prefix mode a "/" means not to change the URI
18924 - [BUG] do not dequeue requests on a dead server
18925 - [BUG] do not dequeue the backend's pending connections on a dead server
18926 - [MINOR] stats: indicate if a task is running in "show sess"
18927 - [BUG] check timeout must not be changed if timeout.check is not set
18928 - [BUG] "option transparent" is for backend, not frontend !
18929 - [MINOR] transfer errors were not reported anymore in data phase
18930 - [MEDIUM] add a send limit to a buffer
18931 - [MEDIUM] don't report buffer timeout when there is I/O activity
18932 - [MEDIUM] indicate when we don't care about read timeout
18933 - [MINOR] add flags to indicate when a stream interface is waiting for space/data
18934 - [MEDIUM] enable inter-stream_interface wakeup calls
18935 - [MAJOR] implement autonomous inter-socket forwarding
18936 - [MINOR] add the splice_len member to the buffer struct in preparation of splice support
18937 - [MEDIUM] stream_sock: factor out the return path in case of no-writes
18938 - [MEDIUM] i/o: rework ->to_forward and ->send_max
18939 - [OPTIM] stream_sock: do not ask for polling on EAGAIN if we have read
18940 - [OPTIM] buffer: replace rlim by max_len
18941 - [OPTIM] stream_sock: factor out the buffer full handling out of the loop
18942 - [CLEANUP] replace a few occurrences of (flags & X) && !(flags & Y)
18943 - [CLEANUP] stream_sock: move the write-nothing condition out of the loop
18944 - [MEDIUM] split stream_sock_write() into callback and core functions
18945 - [MEDIUM] stream_sock_read: call ->chk_snd whenever there are data pending
18946 - [MINOR] stream_sock: fix a few wrong empty calculations
18947 - [MEDIUM] stream_sock: try to send pending data on chk_snd()
18948 - [MINOR] global.maxpipes: add the ability to reserve file descriptors for pipes
18949 - [MEDIUM] splice: add configuration options and set global.maxpipes
18950 - [MINOR] introduce structures required to support Linux kernel splicing
18951 - [MEDIUM] add definitions for Linux kernel splicing
18952 - [MAJOR] complete support for linux 2.6 kernel splicing
18953 - [BUG] reserve some pipes for backends with splice enabled
18954 - [MEDIUM] splice: add hints to support older buggy kernels
18955 - [MEDIUM] introduce pipe pools
18956 - [MEDIUM] splice: make use of pipe pools
18957 - [STATS] report pipe usage in the statistics
18958 - [OPTIM] make global.maxpipes default to global.maxconn/4 when not specified
18959 - [BUILD] fix snapshot date extraction with negative timezones
18960 - [MEDIUM] move global tuning options to the global structure
18961 - [MEDIUM] splice: add the global "nosplice" option
18962 - [BUILD] add USE_LINUX_SPLICE to enable LINUX_SPLICE on linux 2.6
18963 - [BUG] we must not exit if protocol binding only returns a warning
18964 - [MINOR] add support for bind interface name
18965 - [BUG] inform the user when root is expected but not set
18966 - [MEDIUM] add support for source interface binding
18967 - [MEDIUM] add support for source interface binding at the server level
18968 - [MEDIUM] implement bind-process to limit service presence by process
18969 - [DOC] document maxpipes, nosplice, option splice-{auto,request,response}
18970 - [DOC] filled the logging section of the configuration manual
18971 - [DOC] document HTTP status codes
18972 - [DOC] document a few missing info about errorfile
18973 - [BUG] fix random memory corruption using "show sess"
18974 - [BUG] fix unix socket processing of interrupted output
18975 - [DOC] add diagrams of queuing and future ACL design
18976 - [BUILD] proto_http did not build on gcc-2.95
18977 - [BUG] the "source" keyword must first clear optional settings
18978 - [BUG] global.tune.maxaccept must be limited even in mono-process mode
18979 - [MINOR] ensure that http_msg_analyzer updates pointer to invalid char
18980 - [MEDIUM] store a complete dump of request and response errors in proxies
18981 - [MEDIUM] implement error dump on unix socket with "show errors"
18982 - [DOC] document "show errors"
18983 - [MINOR] errors dump must use user-visible date, not internal date.
18984 - [MINOR] time: add __usec_to_1024th to convert usecs to 1024th of second
18985 - [MINOR] add curr_sec_ms and curr_sec_ms_scaled for current second.
18986 - [MEDIUM] measure and report session rate on frontend, backends and servers
18987 - [BUG] the "connslots" keyword was matched as "connlots"
18988 - [MINOR] acl: add 2 new verbs: fe_sess_rate and be_sess_rate
18989 - [MEDIUM] implement "rate-limit sessions" for the frontend
18990 - [BUG] interface binding: length must include the trailing zero
18991 - [BUG] typo in timeout error reporting : report *res and not *err
18992 - [OPTIM] maintain_proxies: only wake up when the frontend will be ready
18993 - [OPTIM] rate-limit: cleaner behaviour on low rates and reduce consumption
18994 - [BUG] switch server-side stream interface to close in case of abort
18995 - [CLEANUP] remove last references to term_trace
18996 - [OPTIM] freq_ctr: do not rotate the counters when reading
18997 - [BUG] disable any analysers for monitoring requests
18998 - [BUG] rate-limit in defaults section was ignored
18999 - [BUG] task: fix handling of duplicate keys
19000 - [OPTIM] task: don't unlink a task from a wait queue when waking it up
19001 - [OPTIM] displace tasks in the wait queue only if absolutely needed
19002 - [MEDIUM] minor update to the task api: let the scheduler queue itself
19003 - [BUG] event_accept() must always wake the task up, even in health mode
19004 - [CLEANUP] task: distinguish between clock ticks and timers
19005 - [OPTIM] task: reduce the number of calls to task_queue()
19006 - [OPTIM] do not re-check req buffer when only response has changed
19007 - [CLEANUP] don't enable kernel splicing when socket is closed
19008 - [CLEANUP] buffer_flush() was misleading, rename it as buffer_erase
19009 - [MINOR] buffers: implement buffer_flush()
19010 - [MEDIUM] rearrange forwarding condition to enable splice during analysis
19011 - [BUILD] build fixes for Solaris
19012 - [BUILD] proto_http did not build on gcc-2.95 (again)
19013 - [CONTRIB] halog: fast log parser for haproxy
19014 - [CONTRIB] halog: faster fgets() and add support for percentile reporting
19015
Willy Tarreau7b4c5ae2008-04-19 21:06:14 +0200190162008/04/19 : 1.3.15
19017 - [BUILD] Added support for 'make install'
19018 - [BUILD] Added 'install-man' make target for installing the man page
19019 - [BUILD] Added 'install-bin' make target
19020 - [BUILD] Added 'install-doc' make target
19021 - [BUILD] Removed "/" after '$(DESTDIR)' in install targets
19022 - [BUILD] Changed 'install' target to install the binaries first
19023 - [BUILD] Replace hardcoded 'LD = gcc' with 'LD = $(CC)'
19024 - [MEDIUM]: Inversion for options
19025 - [MEDIUM]: Count retries and redispatches also for servers, fix redistribute_pending, extend logs, %d->%u cleanup
19026 - [BUG]: Restore clearing t->logs.bytes
19027 - [MEDIUM]: rework checks handling
19028 - [DOC] Update a "contrib" file with a hint about a scheme used for formathing subjects
19029 - [MEDIUM] Implement "track [<backend>/]<server>"
19030 - [MINOR] Implement persistent id for proxies and servers
19031 - [BUG] Don't increment server connections too much + fix retries
19032 - [MEDIUM]: Prevent redispatcher from selecting the same server, version #3
19033 - [MAJOR] proto_uxst rework -> SNMP support
19034 - [BUG] appsession lookup in URL does not work
19035 - [BUG] transparent proxy address was ignored in backend
19036 - [BUG] hot reconfiguration failed because of a wrong error check
19037 - [DOC] big update to the configuration manual
19038 - [DOC] large update to the configuration manual
19039 - [DOC] document more options
19040 - [BUILD] major rework of the GNU Makefile
19041 - [STATS] add support for "show info" on the unix socket
19042 - [DOC] document options forwardfor to logasap
19043 - [MINOR] add support for the "backlog" parameter
19044 - [OPTIM] introduce global parameter "tune.maxaccept"
19045 - [MEDIUM] introduce "timeout http-request" in frontends
19046 - [MINOR] tarpit timeout is also allowed in backends
19047 - [BUG] increment server connections for each connect()
19048 - [MEDIUM] add a turn-around state of one second after a connection failure
19049 - [BUG] fix typo in redispatched connection
19050 - [DOC] document options nolinger to ssl-hello-chk
19051 - [DOC] added documentation for "option tcplog" to "use_backend"
19052 - [BUG] connect_server: server might not exist when sending error report
19053 - [MEDIUM] support fully transparent proxy on Linux (USE_LINUX_TPROXY)
19054 - [MEDIUM] add non-local bind to connect() on Linux
19055 - [MINOR] add transparent proxy support for balabit's Tproxy v4
19056 - [BUG] use backend's source and not server's source with tproxy
19057 - [BUG] fix overlapping server flags
19058 - [MEDIUM] fix server health checks source address selection
19059 - [BUG] build failed on CONFIG_HAP_LINUX_TPROXY without CONFIG_HAP_CTTPROXY
19060 - [DOC] added "server", "source" and "stats" keywords
19061 - [DOC] all server parameters have been documented
19062 - [DOC] document all req* and rsp* keywords.
19063 - [DOC] added documentation about HTTP header manipulations
19064 - [BUG] log response byte count, not request
19065 - [BUILD] code did not build in full debug mode
19066 - [BUG] fix truncated responses with sepoll
19067 - [MINOR] use s->frt_addr as the server's address in transparent proxy
19068 - [MINOR] fix configuration hint about timeouts
19069 - [DOC] minor cleanup of the doc and notice to contributors
19070 - [MINOR] report correct section type for unknown keywords.
19071 - [BUILD] update MacOS Makefile to build on newer versions
19072 - [DOC] fix erroneous "useallbackups" option in the doc
19073 - [DOC] applied small fixes from early readers
19074 - [MINOR] add configuration support for "redir" server keyword
19075 - [MEDIUM] completely implement the server redirection method
19076 - [TESTS] add a test case for the server redirection mechanism
19077 - [DOC] add a configuration entry for "server ... redir <prefix>"
19078 - [BUILD] backend.c and checks.c did not build without tproxy !
19079 - Revert "[BUILD] backend.c and checks.c did not build without tproxy !"
19080 - [BUILD] backend.c and checks.c did not build without tproxy !
19081 - [OPTIM] used unsigned ints for HTTP state and message offsets
19082 - [OPTIM] GCC4's builtin_expect() is suboptimal
19083 - [BUG] failed conns were sometimes incremented in the frontend!
19084 - [BUG] timeout.check was not pre-set to eternity
19085 - [TESTS] add test-pollers.cfg to easily report pollers in use
19086 - [BUG] do not apply timeout.connect in checks if unset
19087 - [BUILD] ensure that makefile understands USE_DLMALLOC=1
19088 - [MINOR] silent gcc for a wrong warning
19089 - [CLEANUP] update .gitignore to ignore more temporary files
19090 - [CLEANUP] report dlmalloc's source path only if explictly specified
19091 - [BUG] str2sun could leak a small buffer in case of error during parsing
19092 - [BUG] option allbackups was not working anymore in roundrobin mode
19093 - [MAJOR] implementation of the "leastconn" load balancing algorithm
19094 - [BUILD] ensure that users don't build without setting the target anymore.
19095 - [DOC] document the leastconn LB algo
19096 - [MEDIUM] fix stats socket limitation to 16 kB
19097 - [DOC] fix unescaped space in httpchk example.
19098 - [BUG] fix double-decrement of server connections
19099 - [TESTS] add a test case for port mapping
19100 - [TESTS] add a benchmark for integer hashing
19101 - [TESTS] add new methods in ip-hash test file
19102 - [MAJOR] implement parameter hashing for POST requests
19103
Willy Tarreaue5b77e82007-12-06 01:25:44 +0100191042007/12/06 : 1.3.14
19105 - New option http_proxy (Alexandre Cassen)
19106 - add support for "maxqueue" to limit server queue overload (Elijah Epifanov)
19107 - Check for duplicated conflicting proxies (Krzysztof Oledzki)
19108 - stats: report server and backend cumulated downtime (Krzysztof Oledzki)
19109 - use backends only with use_backend directive (Krzysztof Oledzki)
19110 - Handle long lines properly (Krzysztof Oledzki)
19111 - Implement and use generic findproxy and relax duplicated proxy check (Krzysztof Oledzki)
19112 - continous statistics (Krzysztof Oledzki)
19113 - add support for logging via a UNIX socket (Robert Tsai)
19114 - fix error checking in strl2ic/strl2uic()
19115 - fix calls to localtime()
19116 - provide easier-to-use ultoa_* functions
19117 - provide easy-to-use limit_r and LIM2A* macros
19118 - add a simple test for the status page
19119 - move error codes to common/errors.h
19120 - silent warning about LIST_* being redefined on OpenBSD
19121 - add socket address length to the protocols
19122 - group PR_O_BALANCE_* bits into a checkable value
19123 - externalize the "balance" option parser to backend.c
19124 - introduce the "url_param" balance method
19125 - make default_backend work in TCP mode too
19126 - disable warning about localtime_r on Solaris
19127 - adjust error messages about conflicting proxies
19128 - avoid calling some layer7 functions if not needed
19129 - simplify error path in event_accept()
19130 - add an options field to the listeners
19131 - added a new state to listeners
19132 - unbind_listener() must use fd_delete() and not close()
19133 - add a generic unbind_listener() primitive
19134 - add a generic delete_listener() primitive
19135 - add a generic unbind_all_listeners() primitive
19136 - create proto_tcp and move initialization of proxy listeners
19137 - stats: report numerical process ID, proxy ID and server ID
19138 - relative_pid was not initialized
19139 - missing header names in raw stats output
19140 - fix missing parenthesis in check_response_for_cacheability
19141 - small optimization on session_process_counters()
19142 - merge ebtree version 3.0
19143 - make ebtree headers multiple-include compatible
19144 - ebtree: include config.h for REGPRM*
19145 - differentiate between generic LB params and map-specific ones
19146 - add a weight divisor to the struct proxy
19147 - implement the Fast Weighted Round Robin (FWRR) algo
19148 - include filltab25.c to experiment on FWRR for dynamic weights
19149 - merge test-fwrr.cfg to validate dynamic weights
19150 - move the load balancing algorithm to be->lbprm.algo
19151 - change server check result to a bit field
19152 - implement "http-check disable-on-404" for graceful shutdown
19153 - secure the calling conditions of ->set_server_status_{up,down}
19154 - report disabled servers as "NOLB" when they are still UP
19155 - document the "http-check disable-on-404" option
19156 - http-check disable-on-404 is not limited to HTTP mode
19157 - add a test file for disable-on-404
19158 - use distinct bits per load-balancing algorithm type
19159 - implement the slowstart parameter for servers
19160 - document the server's slowstart parameter
19161 - stats: report the server warm up status in a "throttle" column
19162 - fix 2 minor issues on AIX
19163 - add the "nbsrv" ACL verb
19164 - add the "fail" condition to monitor requests
19165 - remove a warning from gcc due to htons() in standard.c
19166 - fwrr: ensure that we never overflow in placements
19167 - store the build options to report with -vv
19168 - fix the status return of the init script (R.I. Pienaar)
19169 - stats: real time monitoring script for unix socket (Prizee)
19170 - document "nbsrv" and "monitor fail"
19171 - restrict the set of allowed characters for identifiers
19172 - implement a time parsing function
19173 - add support for time units in the configuration
19174 - add a bit of documentation about timers
19175 - introduce separation between contimeout, and tarpit + queue
19176 - introduce the "timeout" keyword
19177 - grouped all timeouts in one structure
19178 - slowstart is in ms, not seconds
19179 - slowstart: ensure we don't start with a null weight
19180 - report the number of times each server was selected
19181 - fix build on AIX due to recent log changes
19182 - fix build on Solaris due to recent log changes
19183
Willy Tarreaue855f422007-10-18 22:38:22 +0200191842007/10/18 : 1.3.13
19185 - replace the code under O'Reilly license (Arnaud Cornet)
19186 - add a small man page (Arnaud Cornet)
19187 - stats: report haproxy's version by default (Krzysztof Oledzki)
19188 - stats: count server retries and redispatches (Krzysztof Oledzki)
19189 - core: added easy support for Doug Lea's malloc (dlmalloc)
19190 - core: fade out memory usage when stopping proxies
19191 - core: moved the sockaddr pointer to the fdtab structure
19192 - core: add generic protocol support
19193 - core: implement client-side support for PF_UNIX sockets
19194 - stats: implement the CSV output
19195 - stats: add a link to the CSV export HTML page
19196 - stats: implement the statistics output on a unix socket
19197 - config: introduce the "stats" keyword in global section
19198 - build: centralize version and date into one file for each
19199 - tests: added a new hash algorithm
19200
192012007/10/18 : 1.3.12.3
19202 - add the "nolinger" option to disable data lingering (Alexandre Cassen)
19203 - fix double-free during clean exit (Krzysztof Oledzki)
19204 - prevent the system from sending an RST when closing health-checks
19205 (Krzysztof Oledzki)
19206 - do not add a cache-control header when on non-cacheable responses
19207 (Krzysztof Oledzki)
19208 - spread health checks even more (Krzysztof Oledzki)
19209 - stats: scope "." must match the backend and not the frontend
19210 - fixed call to chroot() during startup
19211 - fix wrong timeout computation in event_accept()
19212 - remove condition for exit() under fork() failure
19213
192142007/09/20 : 1.3.12.2
19215 - fix configuration sanity checks for TCP listeners
19216 - set the log socket receive window to zero bytes
19217 - pre-initialize timeouts to infinity, not zero
19218 - fix the SIGHUP message not to alert on server-less proxies
19219 - timeouts and retries could be ignored when switching backend
19220 - added a file to check that "retries" works.
19221 - O'Reilly has clarified its license
19222
192232007/09/05 : 1.3.12.1
19224 - spec I/O: fix allocations of spec entries for an FD
19225 - ensure we never overflow in chunk_printf()
19226 - improve behaviour with large number of servers per proxy
19227 - add support for "stats refresh <interval>"
19228 - stats page: added links for 'refresh' and 'hide down'
19229 - fix backend's weight in the stats page.
19230 - the "stats" keyword is not allowed in a pure frontend.
19231 - provide a test configuration file for stats and checks
19232
Willy Tarreaub21152b2007-06-17 23:41:40 +0200192332007/06/17 : 1.3.12
19234 - fix segfault at exit when using captures
19235 - bug: negation in ACL conds was not cleared between terms
19236 - errorfile: use a local file to feed error messages
19237 - acl: support '-i' to ignore case when matching
19238 - acl: smarter integer comparison with operators eq,lt,gt,le,ge
19239 - acl: support maching on 'path' component
19240 - acl: implement matching on header values
19241 - acl: distinguish between request and response headers
19242 - acl: permit to return any header when no name specified
19243 - acl: provide default ACLs
19244 - added the 'use_backend' keyword for full content-switching
19245 - acl: specify the direction during fetches
19246 - acl: provide the argument length for fetch functions
19247 - acl: provide a reference to the expr to fetch()
19248 - improve memory freeing upon exit
19249 - str2net() must not change the const char *
19250 - shut warnings 'is*' macros from ctype.h on solaris
19251
Willy Tarreaua3503e02007-06-03 17:27:07 +0200192522007/06/03 : 1.3.11.4
19253 - do not re-arm read timeout in SHUTR state !
19254 - optimize I/O by detecting system starvation
19255 - the epoll FD must not be shared between processes
19256 - limit the number of events returned by *poll*
19257
Willy Tarreau3c6fc072007-05-14 14:40:25 +0200192582007/05/14 : 1.3.11.3
19259 - pre-initialize timeouts with tv_eternity during parsing
19260
Willy Tarreaufc273c22007-05-14 03:42:47 +0200192612007/05/14 : 1.3.11.2
19262 - fixed broken health-checks since switch to timeval
19263
Willy Tarreau3c5340c2007-05-14 03:18:43 +0200192642007/05/14 : 1.3.11.1
19265 - fixed ev_kqueue which was forgotten during the switch to timeval
19266 - allowed null timeouts for past events in select
19267
Willy Tarreau544eb402007-05-14 02:42:33 +0200192682007/05/14 : 1.3.11
19269 - fixed ev_sepoll again by rewriting the state machine
19270 - switched all timeouts to timevals instead of milliseconds
19271 - improved memory management using mempools v2.
19272 - several minor optimizations
19273
Willy Tarreau9ca931f2007-05-10 07:51:17 +0200192742007/05/09 : 1.3.10.2
19275 - fixed build on OpenBSD (missing types.h)
19276
Willy Tarreau13398d32007-05-09 22:58:28 +0200192772007/05/09 : 1.3.10.1
19278 - fixed sepoll transition matrix (two states were missing)
19279
Willy Tarreau61beedf2007-05-09 01:44:58 +0200192802007/05/08 : 1.3.10
19281 - several fixes in ev_sepoll
19282 - fixed some expiration dates on some tasks
19283 - fixed a bug in connection establishment detection due to speculative I/O
19284 - fixed rare bug occuring on TCP with early close (reported by Andy Smith)
19285 - implemented URI hashing algorithm (Guillaume Dallaire)
19286 - implemented SMTP health checks (Peter van Dijk)
19287 - replaced the rbtree with ul2tree from old scheduler project
19288 - new framework for generic ACL support
19289 - added the 'acl' and 'block' keywords to the config language
19290 - added several ACL criteria and matches (IP, port, URI, ...)
19291 - cleaned up and better modularization for some time functions
19292 - fixed list macros
19293 - fixed useless memory allocation in str2net()
19294 - store the original destination address in the session
19295
Willy Tarreau6e0433f2007-04-16 01:18:12 +0200192962007/04/15 : 1.3.9
19297 - modularized the polling mechanisms and use function pointers instead
19298 of macros at many places
19299 - implemented support for FreeBSD's kqueue() polling mechanism
19300 - fixed a warning on OpenBSD : MIN/MAX redefined
19301 - change socket registration order at startup to accomodate kqueue.
19302 - several makefile cleanups to support old shells
19303 - fix build with limits.h once for all
19304 - ev_epoll: do not rely on fd_sets anymore, use changes stacks instead.
19305 - fdtab now holds the results of polling
19306 - implemented support for speculative I/O processing with epoll()
19307 - remove useless calls to shutdown(SHUT_RD), resulting in small speed boost
19308 - auto-registering of pollers at load time
19309
Willy Tarreau42c76592007-04-03 20:30:13 +0200193102007/04/03 : 1.3.8.2
19311 - rewriting either the status line or request line could crash the
19312 process due to a pointer which ought to be reset before parsing.
19313 - rewriting the status line in the response did not work, it caused
19314 a 502 Bad Gateway due to an erroneous state during parsing
19315
Willy Tarreauef6d7612007-04-01 11:06:22 +0200193162007/04/01 : 1.3.8.1
19317 - fix reqadd when no option httpclose is used.
19318 - removed now unused fiprm and beprm from proxies
19319 - split logs into two versions : TCP and HTTP
19320 - added some docs about http headers storage and acls
19321 - added a VIM script for syntax color highlighting (Bruno Michel)
19322
Willy Tarreaud661cc02007-03-26 00:24:56 +0200193232007/03/25 : 1.3.8
19324 - fixed several bugs which might have caused a crash with bad configs
19325 - several optimizations in header processing
19326 - many progresses towards transaction-based processing
19327 - option forwardfor may be used in frontends
19328 - completed HTTP response processing
19329 - some code refactoring between request and response processing
19330 - new HTTP header manipulation functions
19331 - optimizations on the recv() patch to reduce CPU usage under very
19332 high data rates.
19333 - more user-friendly help about the 'usesrc' keyword (CTTPROXY)
19334 - username/groupname support from Marcus Rueckert
19335 - added the "except" keyword to the "forwardfor" option (Bryan German)
19336 - support for health-checks on other addresses (Fabrice Dulaunoy)
19337 - makefile for MacOS 10.4 / Darwin (Dan Zinngrabe)
19338 - do not insert "Connection: close" in HTTP/1.0 messages
19339
Willy Tarreau9cabf702007-01-26 23:49:01 +0100193402007/01/26 : 1.3.7
19341 - fix critical bug introduced with 1.3.6 : an empty request header
19342 may lead to a crash due to missing pointer assignment
19343 - hdr_idx might be left uninitialized in debug mode
19344 - fixed build on FreeBSD due to missing fd_set declaration
19345
Willy Tarreaue7a24382007-01-22 08:57:44 +0100193462007/01/22 : 1.3.6.1
19347 - change in the header chaining broke cookies and authentication
19348
Willy Tarreau49e1ee82007-01-22 00:56:46 +0100193492007/01/22 : 1.3.6
19350 - stats now support the HEAD method too
19351 - extracted http request from the session
19352 - huge rework of the HTTP parser which is now a 28-state FSM.
19353 - linux-style likely/unlikely macros for optimization hints
19354 - do not create a server socket when there's no server
19355 - imported lots of docs
19356
Willy Tarreau5871f8e2007-01-07 02:47:01 +0100193572007/01/07 : 1.3.5
19358 - stats: swap color sets for active and backup servers
19359 - try to guess server check port when unset
19360 - added complete support and doc for TCP Splicing
19361 - replace the wait-queue linked list with an rbtree.
19362 - a few bugfixes and cleanups
19363
Willy Tarreau85270da2007-01-02 00:59:39 +0100193642007/01/02 : 1.3.4
19365 - support for cttproxy on the server side to present the client
19366 address to the server.
19367 - added support for SO_REUSEPORT on Linux (needs kernel patch)
19368 - new RFC2616-compliant HTTP request parser with header indexing
19369 - split proxies in frontends, rulesets and backends
19370 - implemented the 'req[i]setbe' to select a backend depending
19371 on the contents
19372 - added the 'default_backend' keyword to select a default BE.
19373 - new stats page featuring FEs and BEs + bytes in both dirs
19374 - improved log format to indicate the backend and the time in ms.
19375 - lots of cleanups
19376
Willy Tarreau9c9fea42006-10-16 00:03:35 +0200193772006/10/15 : 1.3.3
19378 - fix broken redispatch option in case the connection has already
19379 been marked "in progress" (ie: nearly always).
19380 - support regparm on x86 to speed up some often called functions
19381 - removed a few useless calls to gettimeofday() in log functions.
19382 - lots of 'const char*' cleanups
19383 - turn every FD_* into functions which are faster on recent CPUs
19384
Willy Tarreau690f9aa2006-09-03 11:23:06 +0200193852006/09/03 : 1.3.2
19386 - started the changes towards I/O completion callbacks. stream_sock* have
19387 replaced event_*.
19388 - added the new "reqtarpit" and "reqitarpit" protection features
19389
Willy Tarreau8f2b8552006-07-09 17:11:39 +0200193902006/07/09 : 1.3.1 (1.2.15)
19391 - now, haproxy warns about missing timeout during startup to try to
19392 eliminate all those buggy configurations.
19393 - added "Content-Type: text/html" in responses wherever appropriate, as
19394 suggested by Cameron Simpson.
19395 - implemented "option ssl-hello-chk" to use SSLv3 CLIENT HELLO messages to
19396 test server's health
19397 - implemented "monitor-uri" so that haproxy can reply to a specific URI with
19398 an "HTTP/1.0 200 OK" response. This is useful to validate multiple proxies
19399 at once.
19400
Willy Tarreaub9e98b62006-07-03 10:32:46 +0200194012006/06/29 : 1.3.0
19402 - exploded the whole file into multiple .c and .h. No functionnal
Willy Tarreau8f2b8552006-07-09 17:11:39 +020019403 difference is expected at all.
19404 - fixed a bug by which neither stats nor error messages could be returned if
19405 'clitimeout' was missing.
Willy Tarreaub9e98b62006-07-03 10:32:46 +020019406
willy tarreau7e6328d2006-05-21 23:26:20 +0200194072006/05/21 : 1.2.14
19408 - new HTML status report with the 'stats' keyword.
19409 - added the 'abortonclose' option to better resist traffic surges
19410 - implemented dynamic traffic regulation with the 'minconn' option
19411 - show request time on denied requests
19412 - definitely fixed hot reconf on OpenBSD by the use of SO_REUSEPORT
19413 - now a proxy instance is allowed to run without servers, which is
19414 useful to dedicate one instance to stats
19415 - added lots of error counters
19416 - a missing parenthesis preventd matching of cacheable cookies
19417 - a missing parenthesis in poll_loop() might have caused missed events.
19418
Willy TARREAU4404b7e2006-05-14 10:00:09 +0200194192006/05/14 : 1.2.13.1
19420 - an uninitialized field in the struct session could cause a crash when
19421 the session was freed. This has been encountered on Solaris only.
19422 - Solaris and OpenBSD no not support shutdown() on listening socket. Let's
19423 be nice to them by performing a soft stop if pause fails.
19424
willy tarreauc3a2e072006-05-13 18:51:38 +0200194252006/05/13 : 1.2.13
19426 - 'maxconn' server parameter to do per-server session limitation
19427 - queueing to support non-blocking session limitation
19428 - fixed removal of cookies for cookie-less servers such as backup servers
19429 - two separate wait queues for expirable and non-expirable tasks provide
19430 better performance with lots of sessions.
19431 - some code cleanups and performance improvements
19432 - made state dumps a bit more verbose
19433 - fixed missing checks for NULL srv in dispatch mode
19434 - load balancing on backup servers was not possible in source hash mode.
19435 - two session flags shared the same bit, but fortunately they were not
19436 compatible.
19437
willy tarreauc0d4bbd2006-04-15 21:47:50 +0200194382006/04/15 : 1.2.12
19439 Very few changes preparing for more important changes to support per-server
19440 session limitations and queueing :
19441 - ignore leading empty lines in HTTP requests as suggested by RFC2616.
19442 - added the 'weight' parameter to the servers, limited to 1..256. It applies
19443 to roundrobin and source hash.
19444 - the optional '-s' option could clobber '-st' and '-sf' if compiled in.
19445
willy tarreaue0dd2692006-03-30 16:27:34 +0200194462006/03/30 : 1.2.11.1
19447 - under some conditions, it might have been possible that when the
19448 last dead server became available, it would not have been used
19449 till another one would have changed state. Could not be reproduced
19450 at all, however seems possible from the code.
19451
willy tarreaud2058dc2006-03-25 20:35:41 +0100194522006/03/25 : 1.2.11
19453 - added the '-db' command-line option to disable backgrounding.
19454 - added the -sf/-st command-line arguments which are used to specify
19455 a list of pids to send a FINISH or TERMINATE signal upon startup.
19456 They will also be asked to release their port if a bind fails.
19457 - reworked the startup mechanism to allow the sending of a signal to a list
19458 of old pids if a socket cannot be bound, with a retry for a limited amount
19459 of time (1 second by default).
19460 - added the ability to enforce limits on memory usage.
19461 - added the 'source' load-balancing algorithm which uses the source IP(v4|v6)
19462 - re-architectured the server round-robin mechanism to ease integration of
19463 other algorithms. It now relies on the number of active and backup servers.
19464 - added a counter for the number of active and backup servers, and report
19465 these numbers upon SIGHUP or state change.
19466
willy tarreaubfad5742006-03-23 14:19:11 +0100194672006/03/23 : 1.2.10.1
19468 - while fixing the backup server round-robin "feature", a new bug was
19469 introduced which could miss some backup servers.
19470 - the displayed proxy name was wrong when dumping upon SIGHUP.
19471
willy tarreauaaff30e2006-03-19 21:30:41 +0100194722006/03/19 : 1.2.10
19473 - assert.h is needed when DEBUG is defined.
19474 - ENORMOUS long standing bug affecting the epoll polling system :
19475 event_data is a union, not a structure !
19476 - Make fd management more robust and easier to debug. Also some
19477 micro-optimisations.
19478 - Limit the number of consecutive accept() in multi-process mode.
19479 This produces a more evenly distributed load across the processes and
19480 slightly improves performance by reducing bottlenecks.
19481 - Make health-checks be more regular, and faster to retry after a timeout.
19482 - Fixed some messages to ease parsing of alerts.
19483 - provided a patch to enable epoll on RHEL3 kernels.
19484 - Separated OpenBSD build from the main Makefile into a new one.
19485
willy tarreau50be0172006-03-15 19:41:19 +0100194862006/03/15 : 1.2.9
19487 - haproxy could not be stopped after being paused, it had to be woken up
19488 first. This has been fixed.
19489 - the 'ulimit-n' parameter is now optional and by default computed from
19490 maxconn + the number of listeners + the number of health-checks.
19491 - it is now possible to specify a maximum number of connections at build
19492 time with the SYSTEM_MAXCONN define. The value set in the configuration
19493 file will then be limited to this value, and only the command-line '-n'
19494 option will be able to bypass it. It will prevent against accidental
19495 high memory usage on small systems.
19496 - RFC2616 expects that any HTTP agent accepts multi-line headers. Earlier
19497 versions did not detect a line beginning with a space as the continuation
19498 of previous header. It is now correct.
19499 - health checks sent to servers configured with identical intervals were
19500 sent in perfect synchronisation because the initial time was the same
19501 for all. This could induce high load peaks when fragile servers were
19502 hosting tens of instances for the same application. Now the load is
19503 spread evenly across the smallest interval amongst a listener.
19504 - a new 'forceclose' option was added to make the proxy close the outgoing
19505 channel to the server once it has sent all its headers and the server
19506 starts responding. This helps some servers which don't close upon the
19507 'Connection: close' header. It implies 'option httpclose'.
19508 - there was a bug in the way the backup servers were handled. They were
19509 erroneously load-balanced while the doc said the opposite. Since
19510 load-balanced backup servers is one of the features some people have
19511 been asking for, the problem was fixed to reflect the documented
19512 behaviour and a new option 'allbackups' was introduced to provide the
19513 feature to those who need it.
19514 - a never ending connect() could lead to a fast select() loop if its
19515 timeout times the number of retransmits exceeded the server read or write
19516 timeout, because the later was used to compute select()'s timeout while
19517 the connection timeout was not reached.
19518 - now we initialize the libc's localtime structures very early so that even
19519 under OOM conditions, we can still send dated error messages without
19520 segfaulting.
19521 - the 'daemon' mode implies 'quiet' and disables 'verbose' because file
19522 descriptors are closed.
19523
willy tarreau065f1c02006-01-29 22:10:07 +0100195242006/01/29 : 1.2.8
19525 - fixed a nasty bug affecting poll/epoll which could return unmodified data
19526 from the server to the client, and sometimes lead to memory corruption
19527 crashing the process.
19528 - added the new pause/play mechanism with SIGTTOU/SIGTTIN for hot-reconf.
19529
195302005/12/18 : 1.2.7.1
19531 - the "retries" option was ignored because connect() could not return an
19532 error if the connection failed before the timeout.
19533 - TCP health-checks could not detect a connection refused in poll/epoll
19534 mode.
19535
willy tarreaua56eca72005-12-18 01:34:42 +0100195362005/11/13 : 1.2.7
willy tarreau77bc8542005-12-18 01:31:43 +010019537 - building with -DUSE_PCRE should include PCRE headers and not regex.h. At
19538 least on Solaris, this caused the libc's regex primitives to be used instead
19539 of PCRE, which caused trouble on group references. This is now fixed.
willy tarreaud0fb4652005-12-18 01:32:04 +010019540 - delayed the quiet mode during startup so that most of the startup alerts can
19541 be displayed even in quiet mode.
19542 - display an alert when a listener has no address, invalid or no port, or when
19543 there are no enabled listeners upon startup.
willy tarreau4373b962005-12-18 01:32:31 +010019544 - added "static-pcre" to the list of supported regex options in the Makefile.
willy tarreau77bc8542005-12-18 01:31:43 +010019545
willy tarreaub952e1d2005-12-18 01:31:20 +0100195462005/10/09 : 1.2.7rc (1.1.33rc)
19547 - second batch of socklen_t changes.
19548 - clean-ups from Cameron Simpson.
19549 - because tv_remain() does not know about eternity, using no timeout can
19550 make select() spin around a null time-out. Bug reported by Cameron Simpson.
19551 - client read timeout was not properly set to eternity initialized after an
19552 accept() if it was not set in the config. It remained undetected so long
19553 because eternity is 0 and newly allocated pages are zeroed by the system.
19554 - do not call get_original_dst() when not in transparent mode.
19555 - implemented a workaround for a bug in certain epoll() implementations on
19556 linux-2.4 kernels (epoll-lt <= 0.21).
19557 - implemented TCP keepalive with new options : tcpka, clitcpka, srvtcpka.
19558
willy tarreauc5f73ed2005-12-18 01:26:38 +0100195592005/08/07 : 1.2.6
19560 - clean-up patch from Alexander Lazic fixes build on Debian 3.1 (socklen_t).
19561
195622005/07/06 : 1.2.6-pre5 (1.1.32)
willy tarreau0fe39652005-12-18 01:25:24 +010019563 - added the number of active sessions (proxy/process) in the logs
19564
195652005/07/06 : 1.2.6-pre4 (1.1.32-pre4)
willy tarreaub1285d52005-12-18 01:20:14 +010019566 - the time-out fix introduced in 1.1.25 caused a corner case where it was
19567 possible for a client to keep a connection maintained regardless of the
19568 timeout if the server closed the connection during the HEADER phase,
19569 while the client ignored the close request while doing nothing in the
19570 other direction. This has been fixed now by ensuring that read timeouts
19571 are re-armed when switching to any SHUTW state.
19572
195732005/07/05 : 1.2.6-pre3 (1.1.32-pre3)
19574 - enhanced error reporting in the logs. Now the proxy will precisely detect
19575 various error conditions related to the system and/or process limits, and
19576 generate LOG_EMERG logs indicating that a resource has been exhausted.
19577 - logs will contain two new characters for the error cause : 'R' indicates
19578 a resource exhausted, and 'I' indicates an internal error, though this
19579 one should never happen.
19580 - server connection timeouts can now be reported in the logs (sC), as well
19581 as connections refused because of maxconn limitations (PC).
19582
195832005/07/05 : 1.2.6-pre2 (1.1.32-pre2)
19584 - new global configuration keyword "ulimit-n" may be used to raise the FD
19585 limit to usable values.
19586 - a warning is now displayed on startup if the FD limit is lower than the
19587 configured maximum number of sockets.
19588
195892005/07/05 : 1.2.6-pre1 (1.1.32-pre1)
19590 - new configuration keyword "monitor-net" makes it possible to be monitored
19591 by external devices which connect to the proxy without being logged nor
19592 forwarded to any server. Particularly useful on generic TCPv4 relays.
19593
willy tarreau5dffb602005-12-18 01:15:23 +0100195942005/06/21 : 1.2.5.2
19595 - fixed build on PPC where chars are unsigned by default
19596
willy tarreau08dedbe2005-12-18 01:13:48 +0100195972005/05/02 : 1.2.5.1
19598 - dirty hack to fix a bug introduced with epoll : if we close an FD and
19599 immediately reassign it to another session through a connect(), the
19600 Prev{Read,Write}Events are not updated, which causes trouble detecting
19601 changes, thus leading to many timeouts at high loads.
19602
willy tarreau64a3cc32005-12-18 01:13:11 +0100196032005/04/30 : 1.2.5 (1.1.31)
19604 - changed the runtime argument to disable epoll() to '-de'
19605 - changed the runtime argument to disable poll() to '-dp'
19606 - added global options 'nopoll' and 'noepoll' to do the same at the
19607 configuration level.
19608 - added a 'linux24e' target to the Makefile for Linux 2.4 systems patched to
19609 support epoll().
19610 - changed default FD_SETSIZE to 65536 on Solaris (default=1024)
19611 - conditionned signals redirection to #ifdef DEBUG_MEMORY
19612
willy tarreau1c2ad212005-12-18 01:11:29 +0100196132005/04/26 : 1.2.5-pre4
19614 - made epoll() support a compile-time option : ENABLE_EPOLL
19615 - provided a very little libc replacement for a possibly missing epoll()
19616 implementation which can be enabled by -DUSE_MY_EPOLL
19617 - implemented the poll() poller, which can be enabled with -DENABLE_POLL.
19618 The equivalent runtime argument becomes '-P'. A few tests show that it
19619 performs like select() with many fds, but slightly slower (certainly
19620 because of the higher amount of memory involved).
19621 - separated the 3 polling methods and the tasks scheduler into 4 distinct
19622 functions which makes the code a lot more modular.
19623 - moved some event tables to private static declarations inside the poller
19624 functions.
19625 - the poller functions can now initialize themselves, run, and cleanup.
19626 - changed the runtime argument to enable epoll() to '-E'.
19627 - removed buggy epoll_ctl() code in the client_retnclose() function. This
19628 function was never meant to remove anything.
19629 - fixed a typo which caused glibc to yell about a double free on exit.
19630 - removed error checking after epoll_ctl(DEL) because we can never know if
19631 the fd is still active or already closed.
19632 - added a few entries in the makefile
19633
willy tarreauad90a0c2005-12-18 01:09:15 +0100196342005/04/25 : 1.2.5-pre3
19635 - experimental epoll() support (use temporary '-e' argument)
19636
196372005/04/24 : 1.2.5-pre2
willy tarreauc1f47532005-12-18 01:08:26 +010019638 - implemented the HTTP 303 code for error redirection. This forces the
19639 browser to fetch the given URI with a GET request. The new keyword for
19640 this is 'errorloc303', and a new 'errorloc302' keyword has been created
19641 to make them easily distinguishable.
19642 - added more controls in the parser for valid use of '\x' sequence.
19643 - few fixes from Alex & Klaus
19644
willy tarreauad90a0c2005-12-18 01:09:15 +0100196452005/02/17 : 1.2.5-pre1
willy tarreauc1f47532005-12-18 01:08:26 +010019646 - fixed a few errors in the documentation
19647
196482005/02/13
19649 - do not pre-initialize unused file-descriptors before select() anymore.
19650
willy tarreau12350152005-12-18 01:03:27 +0100196512005/01/22 : 1.2.4
19652 - merged Alexander Lazic's and Klaus Wagner's work on application
19653 cookie-based persistence. Since this is the first merge, this version is
19654 not intended for general use and reports are more than welcome. Some
19655 documentation is really needed though.
19656
willy tarreau0174f312005-12-18 01:02:42 +0100196572005/01/22 : 1.2.3 (1.1.30)
19658 - add an architecture guide to the documentation
19659 - released without any changes
19660
196612004/12/26 : 1.2.3-pre1 (1.1.30-pre1)
19662 - increased default BUFSIZE to 16 kB to accept max headers of 8 kB which is
19663 compatible with Apache. This limit can be configured in the makefile now.
19664 Thanks to Eric Fehr for the checks.
19665 - added a per-server "source" option which now makes it possible to bind to
19666 a different source for each (potentially identical) server.
19667 - changed cookie-based server selection slightly to allow several servers to
19668 share a same cookie, thus making it possible to associate backup servers to
19669 live servers and ease soft-stop for maintenance periods. (Alexander Lazic)
19670 - added the cookie 'prefix' mode which makes it possible to use persistence
19671 with thin clients which support only one cookie. The server name is prefixed
19672 before the application cookie, and restore back.
19673 - fixed the order of servers within an instance to match documentation. Now
19674 the servers are *really* used in the order of their declaration. This is
19675 particularly important when multiple backup servers are in use.
19676
willy tarreau4302f492005-12-18 01:00:37 +0100196772004/10/18 : 1.2.2 (1.1.29)
19678 - fixed a bug where a TCP connection would be logged twice if the 'logasap'
19679 option was enabled without the 'tcplog' option.
19680 - encode_string() would use hdr_encode_map instead of the map argument.
19681
196822004/08/10 : (1.1.29-pre2)
19683 - the logged request is now encoded with '#XX' for unprintable characters
19684 - new keywords 'capture request header' and 'capture response header' enable
19685 logging of arbitrary HTTP headers in requests and responses
19686 - removed "-DSOLARIS" after replacing the last inet_aton() with inet_pton()
19687
willy tarreau982249e2005-12-18 00:57:06 +0100196882004/06/06 : 1.2.1 (1.1.28)
19689 - added the '-V' command line option to verbosely report errors even though
19690 the -q or 'quiet' options are specified. This is useful with '-c'.
19691 - added a Red Hat init script and a .spec from Simon Matter <simon.matter@invoca.ch>
willy tarreau036e1ce2005-12-17 13:46:33 +010019692
willy tarreau982249e2005-12-18 00:57:06 +0100196932004/06/05 :
19694 - added the "logasap" option which produces a log without waiting for the data
19695 to be transferred from the server to the client.
19696 - added the "httpclose" option which removes any "connection:" header and adds
19697 "Connection: close" in both direction.
willy tarreau97f58572005-12-18 00:53:44 +010019698 - added the 'checkcache' option which blocks cacheable responses containing
19699 dangerous headers, such as 'set-cookie'.
willy tarreau982249e2005-12-18 00:57:06 +010019700 - added 'rspdeny' and 'rspideny' to block certain responses to avoid sensible
19701 information leak from servers.
willy tarreau25c4ea52005-12-18 00:49:49 +010019702
197032004/04/18 :
willy tarreaudd07e972005-12-18 00:48:48 +010019704 - send an EMERG log when no server is available for a given proxy
19705 - added the '-c' command line option to syntactically check the
19706 configuration file without starting the service.
19707
willy tarreau8a86dbf2005-12-18 00:45:59 +0100197082003/11/09 : 1.2.0
19709 - the same as 1.1.27 + IPv6 support on the client side
19710
willy tarreaufe2c5c12005-12-17 14:14:34 +0100197112003/10/27 : 1.1.27
19712 - the configurable HTTP health check introduced in 1.1.23 revealed a shameful
19713 bug : the code still assumed that HTTP requests were the same size as the
19714 original ones (22 bytes), and failed if they were not.
19715 - added support for pidfiles.
19716
willy tarreauc58fc692005-12-17 14:13:08 +0100197172003/10/22 : 1.1.26
19718 - the fix introduced in 1.1.25 for client timeouts while waiting for servers
19719 broke almost all compatibility with POST requests, because the proxy
19720 stopped to read anything from the client as soon as it got all of its
19721 headers.
19722
willy tarreauc1cae632005-12-17 14:12:23 +0100197232003/10/15 : 1.1.25
19724 - added the 'tcplog' option, which provides enhanced, HTTP-like logs for
19725 generic TCP proxies, or lighter logs for HTTP proxies.
19726 - fixed a time-out condition wrongly reported as client time-out in data
19727 phase if the client timeout was lower than the connect timeout times the
19728 number of retries.
19729
willy tarreau197e8ec2005-12-17 14:10:59 +0100197302003/09/21 : 1.1.24
19731 - if a client sent a full request then shut its write connection down, then
19732 the request was aborted. This case was detected only when using haproxy
19733 both as health-check client and as a server.
19734 - if 'option httpchk' is used in a 'health' mode server, then responses will
19735 change from 'OK' to 'HTTP/1.0 200 OK'.
19736 - fixed a Linux-only bug in case of HTTP server health-checks, where a single
19737 server response followed by a close could be ignored, and the server seen
19738 as failed.
19739
willy tarreaueedaa9f2005-12-17 14:08:03 +0100197402003/09/19 : 1.1.23
19741 - fixed a stupid bug introduced in 1.1.22 which caused second and subsequent
19742 'default' sections to keep previous parameters, and not initialize logs
19743 correctly.
19744 - fixed a second stupid bug introduced in 1.1.22 which caused configurations
19745 relying on 'dispatch' mode to segfault at the first connection.
19746 - 'option httpchk' now supports method, HTTP version and a few headers.
19747 - now, 'option httpchk', 'cookie' and 'capture' can be specified in
19748 'defaults' section
19749
197502003/09/10 : 1.1.22
willy tarreaua41a8b42005-12-17 14:02:24 +010019751 - 'listen' now supports optionnal address:port-range lists
19752 - 'bind' introduced to add new listen addresses
19753 - fixed a bug which caused a session to be kept established on a server till
19754 it timed out if the client closed during the DATA phase.
19755 - the port part of each server address can now be empty to make the proxy
19756 connect to the server on the same port it was connected to, be an absolute
19757 unsigned number to reflect a single port (as in older versions), or an
19758 explicitly signed number (+N/-N) to indicate that this offset must be
19759 applied to the port the proxy was connected to, when connecting to the
19760 server.
19761 - the 'port' server option allows the user to specify a different
19762 health-check port than the service one. It is mandatory when only relative
19763 ports have been specified and check is required. By default, the checks are
19764 sent to the service port.
19765 - new 'defaults' section which is rather similar to 'listen' except that all
19766 values are only used as default values for future 'listen' sections, until
19767 a new 'defaults' resets them. At the moment, server options, regexes,
19768 cookie names and captures cannot be set in the 'defaults' section.
19769
willy tarreau2f6ba652005-12-17 13:57:42 +0100197702003/05/06 : 1.1.21
19771 - changed the debug output format so that it now includes the session unique
19772 ID followed by the instance name at the beginning of each line.
19773 - in debug mode, accept now shows the client's IP and port.
19774 - added one 3 small debugging scripts to search and pretty print debug output
19775 - changed the default health check request to "OPTIONS /" instead of
19776 "OPTIONS *" since not all servers implement the later one.
19777 - "option httpchk" now accepts an optional parameter allowing the user to
19778 specify and URI other than '/' during health-checks.
19779
willy tarreaub1ff9db2005-12-17 13:51:03 +0100197802003/04/21 : 1.1.20
19781 - fixed two problems with time-outs, one where a server would be logged as
19782 timed out during transfer that take longer to complete than the fixed
19783 time-out, and one where clients were logged as timed-out during the data
19784 phase because they didn't have anything to send. This sometimes caused
19785 slow client connections to close too early while in fact there was no
19786 problem. The proper fix would be to have a per-fd time-out with
19787 conditions depending on the state of the HTTP FSM.
19788
willy tarreau906b2682005-12-17 13:49:52 +0100197892003/04/16 : 1.1.19
19790 - haproxy was NOT RFC compliant because it was case-sensitive on HTTP
19791 "Cookie:" and "Set-Cookie:" headers. This caused JVM 1.4 to fail on
19792 cookie persistence because it uses "cookie:". Two memcmp() have been
19793 replaced with strncasecmp().
19794
willy tarreau036e1ce2005-12-17 13:46:33 +0100197952003/04/02 : 1.1.18
19796 - Haproxy can be compiled with PCRE regex instead of libc regex, by setting
19797 REGEX=pcre on the make command line.
19798 - HTTP health-checks now use "OPTIONS *" instead of "OPTIONS /".
19799 - when explicit source address binding is required, it is now also used for
19800 health-checks.
19801 - added 'reqpass' and 'reqipass' to allow certain headers but not the request
19802 itself.
19803 - factored several strings to reduce binary size by about 2 kB.
19804 - replaced setreuid() and setregid() with more standard setuid() and setgid().
19805 - added 4 status flags to the log line indicating who ended the connection
19806 first, the sessions state, the validity of the cookie, and action taken on
19807 the set-cookie header.
19808
198092002/10/18 : 1.1.17
19810 - add the notion of "backup" servers, which are used only when all other
19811 servers are down.
19812 - make Set-Cookie return "" instead of "(null)" when the server has no
19813 cookie assigned (useful for backup servers).
19814 - "log" now supports an optionnal level name (info, notice, err ...) above
19815 which nothing is sent.
19816 - replaced some strncmp() with memcmp() for better efficiency.
19817 - added "capture cookie" option which logs client and/or server cookies
19818 - cleaned up/down messages and dump servers states upon SIGHUP
19819 - added a redirection feature for errors : "errorloc <errnum> <url>"
19820 - now we won't insist on connecting to a dead server, even with a cookie,
19821 unless option "persist" is specified.
19822 - added HTTP/408 response for client request time-out and HTTP/50[234] for
19823 server reply time-out or errors.
19824
198252002/09/01 : 1.1.16
19826 - implement HTTP health checks when option "httpchk" is specified.
19827
198282002/08/07 : 1.1.15
19829 - replaced setpgid()/setpgrp() with setsid() for better portability, because
19830 setpgrp() doesn't have the same meaning under Solaris, Linux, and OpenBSD.
19831
198322002/07/20 : 1.1.14
19833 - added "postonly" cookie mode
19834
198352002/07/15 : 1.1.13
19836 - tv_diff used inverted parameters which led to negative times !
19837
198382002/07/13 : 1.1.12
19839 - fixed stats monitoring, and optimized some tv_* for most common cases.
19840 - replaced temporary 'newhdr' with 'trash' to reduce stack size
19841 - made HTTP errors more HTML-fiendly.
19842 - renamed strlcpy() to strlcpy2() because of a slightly difference between
19843 their behaviour (return value), to avoid confusion.
19844 - restricted HTTP messages to HTTP proxies only
19845 - added a 502 message when the connection has been refused by the server,
19846 to prevent clients from believing this is a zero-byte HTTP 0.9 reply.
19847 - changed 'Cache-control:' from 'no-cache="set-cookie"' to 'private' when
19848 inserting a cookie, because some caches (apache) don't understand it.
19849 - fixed processing of server headers when client is in SHUTR state
19850
198512002/07/04 :
19852 - automatically close fd's 0,1 and 2 when going daemon ; setpgrp() after
19853 setpgid()
19854
198552002/06/04 : 1.1.11
19856 - fixed multi-cookie handling in client request to allow clean deletion
19857 in insert+indirect mode. Now, only the server cookie is deleted and not
willy tarreau906b2682005-12-17 13:49:52 +010019858 all the header. Should now be compliant to RFC2965.
willy tarreau036e1ce2005-12-17 13:46:33 +010019859 - added a "nocache" option to "cookie" to specify that we explicitly want
19860 to add a "cache-control" header when we add a cookie.
19861 It is also possible to add an "Expires: <old-date>" to keep compatibility
19862 with old/broken caches.
19863
198642002/05/10 : 1.1.10
19865 - if a cookie is used in insert+indirect mode, it's desirable that the
19866 the servers don't see it. It was not possible to remove it correctly
19867 with regexps, so now it's removed automatically.
19868
198692002/04/19 : 1.1.9
19870 - don't use snprintf()'s return value as an end of message since it may
19871 be larger. This caused bus errors and segfaults in internal libc's
19872 getenv() during localtime() in send_log().
19873 - removed dead insecure send_syslog() function and all references to it.
19874 - fixed warnings on Solaris due to buggy implementation of isXXXX().
19875
198762002/04/18 : 1.1.8
19877 - option "dontlognull"
19878 - fixed "double space" bug in config parser
19879 - fixed an uninitialized server field in case of dispatch
19880 with no existing server which could cause a segfault during
19881 logging.
19882 - the pid logged was always the father's, which was wrong for daemons.
19883 - fixed wrong level "LOG_INFO" for message "proxy started".
19884
198852002/04/13 :
19886 - http logging is now complete :
19887 - ip:port, date, proxy, server
19888 - req_time, conn_time, hdr_time, tot_time
19889 - status, size, request
19890 - source address
19891
198922002/04/12 : 1.1.7
19893 - added option forwardfor
19894 - added reqirep, reqidel, reqiallow, reqideny, rspirep, rspidel
19895 - added "log global" in "listen" section.
19896
198972002/04/09 :
19898 - added a new "global" section :
19899 - logs
19900 - debug, quiet, daemon modes
19901 - uid, gid, chroot, nbproc, maxconn
19902
199032002/04/08 : 1.1.6
19904 - regex are now chained and not limited anymore.
19905 - unavailable server now returns HTTP/502.
19906 - increased per-line args limit to 40
19907 - added reqallow/reqdeny to block some request on matches
19908 - added HTTP 400/403 responses
19909
199102002/04/03 : 1.1.5
19911 - connection logging displayed incorrect source address.
19912 - added proxy start/stop and server up/down log events.
19913 - replaced log message short buffers with larger trash.
19914 - enlarged buffer to 8 kB and replace buffer to 4 kB.
19915
199162002/03/25 : 1.1.4
19917 - made rise/fall/interval time configurable
19918
199192002/03/22 : 1.1.3
19920 - fixed a bug : cr_expire and cw_expire were inverted in CL_STSHUT[WR]
19921 which could lead to loops.
19922
199232002/03/21 : 1.1.2
19924 - fixed a bug in buffer management where we could have a loop
19925 between event_read() and process_{cli|srv} if R==BUFSIZE-MAXREWRITE.
19926 => implemented an adjustable buffer limit.
19927 - fixed a bug : expiration of tasks in wait queue timeout is used again,
19928 and running tasks are skipped.
19929 - added some debug lines for accept events.
19930 - send warnings for servers up/down.
19931
199322002/03/12 : 1.1.1
19933 - fixed a bug in total failure handling
19934 - fixed a bug in timestamp comparison within same second (tv_cmp_ms)
19935
199362002/03/10 : 1.1.0
19937 - fixed a few timeout bugs
19938 - rearranged the task scheduler subsystem to improve performance,
19939 add new tasks, and make it easier to later port to librt ;
19940 - allow multiple accept() for one select() wake up ;
19941 - implemented internal load balancing with basic health-check ;
19942 - cookie insertion and header add/replace/delete, with better strings
19943 support.
19944
199452002/03/08
19946 - reworked buffer handling to fix a few rewrite bugs, and
19947 improve overall performance.
19948 - implement the "purge" option to delete server cookies in direct mode.
19949
199502002/03/07
19951 - fixed some error cases where the maxfd was not decreased.
19952
199532002/02/26
19954 - now supports transparent proxying, at least on linux 2.4.
19955
199562002/02/12
19957 - soft stop works again (fixed select timeout computation).
19958 - it seems that TCP proxies sometimes cannot timeout.
19959 - added a "quiet" mode.
19960 - enforce file descriptor limitation on socket() and accept().
19961
199622001/12/30 : release of version 1.0.2 : fixed a bug in header processing
199632001/12/19 : release of version 1.0.1 : no MSG_NOSIGNAL on solaris
199642001/12/16 : release of version 1.0.0.
199652001/12/16 : added syslog capability for each accepted connection.
199662001/11/19 : corrected premature end of files and occasional SIGPIPE.
199672001/10/31 : added health-check type servers (mode health) which replies OK then closes.
199682001/10/30 : added the ability to support standard TCP proxies and HTTP proxies
19969 with or without cookies (use keyword http for this).
199702001/09/01 : added client/server header replacing with regexps.
19971 eg:
19972 cliexp ^(Host:\ [^:]*).* Host:\ \1:80
19973 srvexp ^Server:\ .* Server:\ Apache
199742000/11/29 : first fully working release with complete FSMs and timeouts.
199752000/11/28 : major rewrite
199762000/11/26 : first write