]> git.ipfire.org Git - thirdparty/haproxy.git/log
thirdparty/haproxy.git
9 years agoMINOR: da: silent logging by default and displaying DeviceAtlas support if built.
David Carlier [Wed, 2 Dec 2015 11:22:53 +0000 (11:22 +0000)] 
MINOR: da: silent logging by default and displaying DeviceAtlas support if built.

9 years agoCLEANUP: proxy: calloc call inverted arguments
David CARLIER [Wed, 25 Nov 2015 15:27:36 +0000 (15:27 +0000)] 
CLEANUP: proxy: calloc call inverted arguments

Nothing major but a human typo mistake.

9 years agoBUILD: dumpstats: silencing warning for printf format specifier / time_t
David Carlier [Wed, 18 Nov 2015 06:10:22 +0000 (06:10 +0000)] 
BUILD: dumpstats: silencing warning for printf format specifier / time_t

time_t is not necesseraly a long int (spotted in OpenBSD), so just an explicit cast to
avoid the compiler warning. should be safe enough.

9 years agoBUG/MEDIUM: sample: urlp can't match an empty value
Cyril Bonté [Thu, 26 Nov 2015 20:39:56 +0000 (21:39 +0100)] 
BUG/MEDIUM: sample: urlp can't match an empty value

Currently urlp fetching samples were able to find parameters with an empty
value, but the return code depended on the value length. The final result was
that acls using urlp couldn't match empty values.

Example of acl which always returned "false":
  acl MATCH_EMPTY urlp(foo) -m len 0

The fix consists in unconditionally return 1 when the parameter is found.

This fix must be backported to 1.6 and 1.5.

9 years agoBUG/MEDIUM: cli: changing compression rate-limiting must require admin level
Willy Tarreau [Thu, 26 Nov 2015 17:32:39 +0000 (18:32 +0100)] 
BUG/MEDIUM: cli: changing compression rate-limiting must require admin level

Right now it's possible to change the global compression rate limiting
without the CLI being at the admin level.

This fix must be backported to 1.6 and 1.5.

9 years agoCLEANUP: compression: don't allocate DEFAULT_MAXZLIBMEM without USE_ZLIB
Willy Tarreau [Thu, 26 Nov 2015 15:34:56 +0000 (16:34 +0100)] 
CLEANUP: compression: don't allocate DEFAULT_MAXZLIBMEM without USE_ZLIB

It's pointless to reserve this amount of memory when zlib is not used.
Adding the condition will make build scripts easier to manage. This may
be backported to 1.6.

9 years agoBUG/MEDIUM: stream: fix half-closed timeout handling
Willy Tarreau [Wed, 25 Nov 2015 19:17:27 +0000 (20:17 +0100)] 
BUG/MEDIUM: stream: fix half-closed timeout handling

client-fin and server-fin are bogus. They are applied on the write
side after a SHUTR was seen. The immediate effect is that sometimes
if a SHUTR was seen after a SHUTW on the same side, the timeout is
enabled again regardless of the fact that the output is already
closed. This results in the timeout event not to be processed and
a busy poll loop to happen until another timeout on the stream gets
rid of it. Note that haproxy continues its job during this, it's just
that it eats all the CPU trying to handle an event that it ignores.

An reproducible case consists in having a client stop reading data from
a server to ensure data remain in the response buffer, then the client
sends a shutdown(write). If abortonclose is enabled on haproxy, the
shutdown is passed to the server side and the server responds with a
SHUTR that cannot immediately be forwarded to the client since the
buffer is full. During this time the event is ignored and the task is
woken again in loops.

It is worth noting that the timeout handling since 1.5 is a bit fragile
and that it might be possible that other similar conditions still exist,
so the timeout handling should be audited regarding this issue.

Many thanks to BaiYang for providing detailed information showing the
problem in action.

This bug also affects 1.5 thus the fix must be backported.

9 years agoBUG/MEDIUM: http: don't enable auto-close on the response side
Willy Tarreau [Wed, 25 Nov 2015 19:11:11 +0000 (20:11 +0100)] 
BUG/MEDIUM: http: don't enable auto-close on the response side

There is a bug where "option http-keep-alive" doesn't force a response
to stay in keep-alive if the server sends the FIN along with the response
on the second or subsequent response. The reason is that the auto-close
was forced enabled when recycling the HTTP transaction and it's never
disabled along the response processing chain before the SHUTR gets a
chance to be forwarded to the client side. The MSG_DONE state of the
HTTP response properly disables it but too late.

There's no more reason for enabling auto-close here, because either it
doesn't matter in non-keep-alive modes because the connection is closed,
or it is automatically enabled by process_stream() when it sees there's
no analyser on the stream.

This bug also affects 1.5 so a backport is desired.

9 years agoBUILD/MINOR: http: proto_http.h needs sample.h
Willy Tarreau [Wed, 25 Nov 2015 10:29:47 +0000 (11:29 +0100)] 
BUILD/MINOR: http: proto_http.h needs sample.h

Since commit fd7edd3 ("MINOR: Move http method enum from proto_http to sample")
proto_http.h needs to include sample.h. This can be backported to 1.6 though
it doesn't affect existing code.

9 years agoBUG/MINOR: lua: don't force-sslv3 LUA's SSL socket
Lukas Tribus [Thu, 26 Nov 2015 00:48:08 +0000 (01:48 +0100)] 
BUG/MINOR: lua: don't force-sslv3 LUA's SSL socket

Sander Klein reported an error messages about SSLv3 not
being supported on Debian 8, although he didn't force-sslv3.

Vincent Bernat tracked this down to the LUA initialization, which
actually does force-sslv3.

This patch removes force-sslv3 from the LUA initialization, so
the LUA SSL socket can actually use TLS and doesn't trigger
warnings when SSLv3 is not supported by libssl (such as in
Debian 8).

This should be backported to 1.6.

9 years agoBUG/MEDIUM: http: switch the request channel to no-delay once done.
Willy Tarreau [Wed, 18 Nov 2015 10:59:55 +0000 (11:59 +0100)] 
BUG/MEDIUM: http: switch the request channel to no-delay once done.

There's an issue when sending POST data that came in a second packet,
the CF_NEVER_WAIT flag is not always set on the request channel, while
the server is waiting for the request. We must always set this flag in
this case since we're not going to shut down after sending, contrary
to the response side.

Note that option http-no-delay works around this issue.

Reproducer :

listen  px
        mode http
        timeout client 10s
        timeout server 5s
        timeout connect 3s
        option http-server-close
        #option http-no-delay
        bind :8001
        server s1 127.0.0.1:8003

$ (printf "POST / HTTP/1.1\r\nTransfer-encoding: chunked\r\n\r\n"; sleep 0.01; printf "10\r\nAZERTYUIOPQSDFGH\r\n0\r\n\r\n") | nc6 0 8001

Before this fix :

12:03:31.946763 epoll_wait(3, {{EPOLLIN, {u32=5, u64=5}}}, 200, 1000) = 1
12:03:32.634175 accept4(5, {sa_family=AF_INET, sin_port=htons(53849), sin_addr=inet_addr("127.0.0.1")}, [16], SOCK_NONBLOCK) = 6
12:03:32.634318 setsockopt(6, SOL_TCP, TCP_NODELAY, [1], 4) = 0
12:03:32.634434 accept4(5, 0x7ffccfbb2cf0, [128], SOCK_NONBLOCK) = -1 EAGAIN (Resource temporarily unavailable)
12:03:32.634574 recvfrom(6, "POST / HTTP/1.1\r\nTransfer-encodi"..., 8192, 0, NULL, NULL) = 47
12:03:32.634809 setsockopt(6, SOL_TCP, TCP_QUICKACK, [1], 4) = 0
12:03:32.634952 socket(PF_INET, SOCK_STREAM, IPPROTO_TCP) = 7
12:03:32.635031 fcntl(7, F_SETFL, O_RDONLY|O_NONBLOCK) = 0
12:03:32.635089 setsockopt(7, SOL_TCP, TCP_NODELAY, [1], 4) = 0
12:03:32.635153 connect(7, {sa_family=AF_INET, sin_port=htons(8003), sin_addr=inet_addr("127.0.0.1")}, 16) = -1 EINPROGRESS (Operation now in progress)
12:03:32.635315 epoll_wait(3, {}, 200, 0) = 0
12:03:32.635394 sendto(7, "POST / HTTP/1.1\r\nTransfer-encodi"..., 66, MSG_DONTWAIT|MSG_NOSIGNAL, NULL, 0) = 66
12:03:32.635527 recvfrom(6, 0x7f0224e66024, 8192, 0, 0, 0) = -1 EAGAIN (Resource temporarily unavailable)
12:03:32.635651 epoll_ctl(3, EPOLL_CTL_ADD, 6, {EPOLLIN|0x2000, {u32=6, u64=6}}) = 0
12:03:32.635782 epoll_wait(3, {}, 200, 0) = 0
12:03:32.635842 recvfrom(7, 0x7f0224e66024, 8192, 0, 0, 0) = -1 EAGAIN (Resource temporarily unavailable)
12:03:32.635924 epoll_ctl(3, EPOLL_CTL_ADD, 7, {EPOLLIN|0x2000, {u32=7, u64=7}}) = 0
12:03:32.636027 epoll_wait(3, {{EPOLLIN, {u32=6, u64=6}}}, 200, 1000) = 1
12:03:32.644892 recvfrom(6, "10\r\nAZERTYUIOPQSDFGH\r\n0\r\n\r\n", 8192, 0, NULL, NULL) = 27
12:03:32.645016 epoll_wait(3, {}, 200, 0) = 0
12:03:32.645105 sendto(7, "10\r\nAZERTYUIOPQSDFGH\r\n0\r\n\r\n", 27, MSG_DONTWAIT|MSG_NOSIGNAL|MSG_MORE, NULL, 0) = 27

After the fix :

11:59:12.538617 connect(7, {sa_family=AF_INET, sin_port=htons(8003), sin_addr=inet_addr("127.0.0.1")}, 16) = -1 EINPROGRESS (Operation now in progress)
11:59:12.538787 epoll_wait(3, {}, 200, 0) = 0
11:59:12.538867 sendto(7, "POST / HTTP/1.1\r\nTransfer-encodi"..., 66, MSG_DONTWAIT|MSG_NOSIGNAL, NULL, 0) = 66
11:59:12.539031 recvfrom(6, 0x7f832ce45024, 8192, 0, 0, 0) = -1 EAGAIN (Resource temporarily unavailable)
11:59:12.539161 epoll_ctl(3, EPOLL_CTL_ADD, 6, {EPOLLIN|0x2000, {u32=6, u64=6}}) = 0
11:59:12.539259 epoll_wait(3, {}, 200, 0) = 0
11:59:12.539337 recvfrom(7, 0x7f832ce45024, 8192, 0, 0, 0) = -1 EAGAIN (Resource temporarily unavailable)
11:59:12.539421 epoll_ctl(3, EPOLL_CTL_ADD, 7, {EPOLLIN|0x2000, {u32=7, u64=7}}) = 0
11:59:12.539499 epoll_wait(3, {{EPOLLIN, {u32=6, u64=6}}}, 200, 1000) = 1
11:59:12.548519 recvfrom(6, "10\r\nAZERTYUIOPQSDFGH\r\n0\r\n\r\n", 8192, 0, NULL, NULL) = 27
11:59:12.548844 epoll_wait(3, {}, 200, 0) = 0
11:59:12.549012 sendto(7, "10\r\nAZERTYUIOPQSDFGH\r\n0\r\n\r\n", 27, MSG_DONTWAIT|MSG_NOSIGNAL, NULL, 0) = 27
11:59:12.549454 epoll_wait(3, {}, 200, 1000) = 0

This fix must be backported to 1.6, 1.5 and 1.4.

9 years agoBUG: http: do not abort keep-alive connections on server timeout
lsenta [Fri, 13 Nov 2015 09:44:22 +0000 (10:44 +0100)] 
BUG: http: do not abort keep-alive connections on server timeout

When a server timeout is detected on the second or nth request of a keep-alive
connection, HAProxy closes the connection without writing a response.
Some clients would fail with a remote disconnected exception and some
others would retry potentially unsafe requests.

This patch removes the special case and makes sure a 504 timeout is
written back whenever a server timeout is handled.

Signed-off-by: lsenta <laurent.senta@gmail.com>
9 years agoBUILD: Make deviceatlas require PCRE
David CARLIER [Fri, 6 Nov 2015 15:13:06 +0000 (15:13 +0000)] 
BUILD: Make deviceatlas require PCRE

Makefile deviceatlas throwing an error if the necessary pcre flag
is not passed avoiding surprising bunch of 'undefined reference'
for the user. Plus a tiny typo in OPENSSL area.

[wt: backport to 1.6]

9 years agoDOC: relation between timeout http-request and option http-buffer-request
Baptiste Assmann [Wed, 28 Oct 2015 12:49:01 +0000 (13:49 +0100)] 
DOC: relation between timeout http-request and option http-buffer-request

The documentation missed the explanation and relation between the
timeout http-request and option http-buffer-request.
Combined together, it helps protecting against slow POST types of
attacks.

[wt: backport to 1.6]

9 years agoDOC: lua: architecture and first steps
Thierry FOURNIER [Sun, 8 Nov 2015 21:02:21 +0000 (22:02 +0100)] 
DOC: lua: architecture and first steps

Add some lua documentation

[wt: should be backported to 1.6]

9 years agoDOC: lua-api/index.rst small example fixes, spelling correction.
Pieter Baauw [Sun, 8 Nov 2015 15:38:08 +0000 (16:38 +0100)] 
DOC: lua-api/index.rst small example fixes, spelling correction.

[wt: backport to 1.6]

9 years agoBUILD: check for libressl to be able to build against it
Daniel Jakots [Fri, 6 Nov 2015 19:02:41 +0000 (20:02 +0100)] 
BUILD: check for libressl to be able to build against it

[wt: might be worth backporting it to 1.6]

9 years agoBUG/MEDIUM: lua: clean output buffer
Thierry FOURNIER [Wed, 4 Nov 2015 09:52:59 +0000 (10:52 +0100)] 
BUG/MEDIUM: lua: clean output buffer

When the txn.done() fiunction is called, the ouput buffer is cleaned,
but the associated relative pointer on the HTTP requests elements
is not reseted.

This patch remove this cleanup, because the output buffer may contain
data to forward.

9 years agoBUILD: freebsd: double declaration
Thierry FOURNIER [Tue, 3 Nov 2015 18:17:37 +0000 (19:17 +0100)] 
BUILD: freebsd: double declaration

On freebsd, the macro LIST_PREV already exists in the header file
<sys/queue.h>, and this makes a build error.

This patch removes the macros before declaring it. This ensure
that the error doesn't occurs.

9 years agoBUG/MINOR: acl: don't use record layer in req_ssl_ver
Lukas Tribus [Thu, 5 Nov 2015 12:59:30 +0000 (13:59 +0100)] 
BUG/MINOR: acl: don't use record layer in req_ssl_ver

The initial record layer version in a SSL handshake may be set to TLSv1.0
or similar for compatibility reasons, this is allowed as per RFC5246
Appendix E.1 [1]. Some implementations are Openssl [2] and NSS [3].

A related issue has been fixed some time ago in commit 57d229747
("BUG/MINOR: acl: req_ssl_sni fails with SSLv3 record version").

Fix this by using the real client hello version instead of the record
layer version.

This was reported by Julien Vehent and analyzed by Cyril Bonté.
The initial patch is from Julien Vehent as well.

This should be backported to stable series, the req_ssl_ver keyword was
first introduced in 1.3.16.

[1] https://tools.ietf.org/html/rfc5246#appendix-E.1
[2] https://github.com/openssl/openssl/commit/4a1cf50187659e60c5867ecbbc36e37b2605d2c3
[3] https://bugzilla.mozilla.org/show_bug.cgi?id=774547

9 years agoBUG/MINOR: server: check return value of fgets() in apply_server_state()
Dragan Dosen [Wed, 4 Nov 2015 22:03:26 +0000 (23:03 +0100)] 
BUG/MINOR: server: check return value of fgets() in apply_server_state()

fgets() can return NULL on error or when EOF occurs. This patch adds a
check of fgets() return value and displays a warning if the first line of
the server state file can not be read. Additionally, we make sure to close
the previously opened file descriptor.

9 years agoBUG/MINOR: http rule: http capture 'id' rule points to a non existing id
Baptiste Assmann [Tue, 3 Nov 2015 22:31:35 +0000 (23:31 +0100)] 
BUG/MINOR: http rule: http capture 'id' rule points to a non existing id

It is possible to create a http capture rule which points to a capture slot
id which does not exist.

Current patch prevent this when parsing configuration and prevent running
configuration which contains such rules.

This configuration is now invalid:

  frontend f
   bind :8080
   http-request capture req.hdr(User-Agent) id 0
   default_backend b

this one as well:

  frontend f
   bind :8080
   declare capture request len 32 # implicit id is 0 here
   http-request capture req.hdr(User-Agent) id 1
   default_backend b

It applies of course to both http-request and http-response rules.

9 years agoMINOR: check: add agent-send server parameter
James Brown [Thu, 22 Oct 2015 01:19:05 +0000 (18:19 -0700)] 
MINOR: check: add agent-send server parameter

Causes HAProxy to emit a static string to the agent on every check,
so that you can independently control multiple services running
behind a single agent port.

9 years agoBUG/MEDIUM: lua: sample fetches based on response doesn't work
Thierry FOURNIER [Mon, 2 Nov 2015 09:01:59 +0000 (10:01 +0100)] 
BUG/MEDIUM: lua: sample fetches based on response doesn't work

The direction (request or response) is not propagated in the
sample fecthes called throught Lua. This patch adds the direction
status in some structs (hlua_txn and hlua_smp) to make sure that
the sample fetches will be called with all the information.

The converters can not access to a TXN object, so there are not
impacted the direction. However, the samples used as input of the
Lua converter wrapper are initiliazed with the direction. Thereby,
the struct smp stay consistent.
[wt: needs to be backported to 1.6]

9 years agoCLEANUP: use direction names in place of numeric values
Thierry FOURNIER [Mon, 2 Nov 2015 08:52:54 +0000 (09:52 +0100)] 
CLEANUP: use direction names in place of numeric values

This patch cleanups the direction names. It replaces numeric values,
by the associated defines. It ensure the compliance with values found
somwhere else in HAProxy.

It is required by the bugfix patch which is following.
[wt: needs to be backported to 1.6]

9 years agoBUG/MINOR: dns: check for duplicate nameserver id in a resolvers section was missing
Baptiste Assmann [Mon, 2 Nov 2015 21:55:49 +0000 (22:55 +0100)] 
BUG/MINOR: dns: check for duplicate nameserver id in a resolvers section was missing

Current resolvers section parsing function is permissive on nameserver
id and two nameservers may have the same id.
It's a shame, since we don't know for example, whose statistics belong
to which nameserver...

From now, configuration with duplicated nameserver id in a resolvers
section are considered as broken and returns a fatal error when parsing.

9 years agoDOC: typo on capture.res.hdr and capture.req.hdr
Baptiste Assmann [Wed, 21 Oct 2015 21:13:46 +0000 (23:13 +0200)] 
DOC: typo on capture.res.hdr and capture.req.hdr

capture.res.hdr and capture.req.hdr were mis-spelled (hdr.req.capture)
in the doc, leading to misunderstandings.

9 years agoBUG/MAJOR: http: don't requeue an idle connection that is already queued
Willy Tarreau [Mon, 2 Nov 2015 19:20:11 +0000 (20:20 +0100)] 
BUG/MAJOR: http: don't requeue an idle connection that is already queued

Cyril Bonté reported a reproduceable sequence which can lead to a crash
when using backend connection reuse. The problem comes from the fact that
we systematically add the server connection to an idle pool at the end of
the HTTP transaction regardless of the fact that it might already be there.

This is possible for example when processing a request which doesn't use
a server connection (typically a redirect) after a request which used a
connection. Then after the first request, the connection was already in
the idle queue and we're putting it a second time at the end of the second
request, causing a corruption of the idle pool.

Interestingly, the memory debugger in 1.7 immediately detected a suspicious
double free on the connection, leading to a very early detection of the
cause instead of its consequences.

Thanks to Cyril for quickly providing a working reproducer.

This fix must be backported to 1.6 since connection reuse was introduced
there.

9 years agoBUILD: add Haiku as supported target.
Jerome Duval [Mon, 19 Oct 2015 23:01:16 +0000 (23:01 +0000)] 
BUILD: add Haiku as supported target.

9 years agoBUG/BUILD: replace haproxy-systemd-wrapper with $(EXTRA) in install-bin.
Jerome Duval [Mon, 2 Nov 2015 17:47:43 +0000 (17:47 +0000)] 
BUG/BUILD: replace haproxy-systemd-wrapper with $(EXTRA) in install-bin.

[wt: this should be backported to 1.6 and 1.5 as well since some platforms
 don't build the systemd-wrapper]

9 years agoMINOR: config: allow IPv6 bracketed literals
mildis [Mon, 26 Oct 2015 17:50:08 +0000 (18:50 +0100)] 
MINOR: config: allow IPv6 bracketed literals

9 years agoDOC: deviceatlas: more example use cases.
David Carlier [Wed, 28 Oct 2015 11:08:15 +0000 (11:08 +0000)] 
DOC: deviceatlas: more example use cases.

In addition of adding additional headers examples, some examples of
defining an ACL.

9 years agoBUG/MINOR: examples/haproxy.init: missing brace in quiet_check()
jesse.defer@asu.edu [Sun, 1 Nov 2015 03:29:56 +0000 (20:29 -0700)] 
BUG/MINOR: examples/haproxy.init: missing brace in quiet_check()

There is a missing curly brace in the quiet_check function of the example
init script.

[note: This needs to be backported to 1.6]

9 years agoBUG/MINOR: dns: unable to parse CNAMEs response
Baptiste Assmann [Wed, 28 Oct 2015 01:10:02 +0000 (02:10 +0100)] 
BUG/MINOR: dns: unable to parse CNAMEs response

A bug lied in the parsing of DNS CNAME response, leading HAProxy to
think the CNAME was improperly resolved in the response.

This should be backported into 1.6 branch

9 years agoBUG/MAJOR: dns: first DNS response packet not matching queried hostname may lead...
Baptiste Assmann [Wed, 28 Oct 2015 01:03:32 +0000 (02:03 +0100)] 
BUG/MAJOR: dns: first DNS response packet not matching queried hostname may lead to a loop

The status DNS_UPD_NAME_ERROR returned by dns_get_ip_from_response and
which means the queried name can't be found in the response was
improperly processed (fell into the default case).
This lead to a loop where HAProxy simply resend a new query as soon as
it got a response for this status and in the only case where such type
of response is the very first one received by the process.

This should be backported into 1.6 branch

9 years agoBUG/MEDIUM: config: count memory limits on 64 bits, not 32
Willy Tarreau [Thu, 29 Oct 2015 09:42:55 +0000 (10:42 +0100)] 
BUG/MEDIUM: config: count memory limits on 64 bits, not 32

It was accidently discovered that limiting haproxy to 5000 MB leads to
an effective limit of 904 MB. This is because the computation for the
size limit is performed by multiplying rlimit_memmax by 1048576, and
doing so causes the operation to be performed on an int instead of a
long or long long. Just switch to 1048576ULL as is done at other places
to fix this.

This bug affects all supported versions, the backport is desired, though
it rarely affects users since few people apply memory limits.

9 years agoMEDIUM: memory: add accounting for failed allocations
Willy Tarreau [Wed, 28 Oct 2015 15:24:21 +0000 (16:24 +0100)] 
MEDIUM: memory: add accounting for failed allocations

We now keep a per-pool counter of failed memory allocations and
we report that, as well as the amount of memory allocated and used
on the CLI.

9 years agoDEBUG/MEDIUM: memory: add optional control pool memory operations
Willy Tarreau [Wed, 28 Oct 2015 14:23:51 +0000 (15:23 +0100)] 
DEBUG/MEDIUM: memory: add optional control pool memory operations

When DEBUG_MEMORY_POOLS is used, we now use the link pointer at the end
of the pool to store a pointer to the pool, and to control it during
pool_free2() in order to serve four purposes :
  - at any instant we can know what pool an object was allocated from
    when examining memory, hence how we should possibly decode it ;

  - it serves to detect double free when they happen, as the pointer
    cannot be valid after the element is linked into the pool ;

  - it serves to detect if an element is released in the wrong pool ;

  - it serves as a canary, to detect if some buffers experienced an
    overflow before being release.

All these elements will definitely help better troubleshoot strange
situations, or at least confirm that certain conditions did not happen.

9 years agoDEBUG/MEDIUM: memory: optionally protect free data in pools
Willy Tarreau [Wed, 28 Oct 2015 14:09:29 +0000 (15:09 +0100)] 
DEBUG/MEDIUM: memory: optionally protect free data in pools

When debugging a core file, it's sometimes convenient to be able to
visit the released entries in the pools (typically last released
session). Unfortunately the first bytes of these entries are destroyed
by the link elements of the pool. And of course, most structures have
their most accessed elements at the beginning of the structure (typically
flags). Let's add a build-time option DEBUG_MEMORY_POOLS which allocates
an extra pointer in each pool to put the link at the end of each pool
item instead of the beginning.

9 years agoDEBUG/MINOR: memory: add a build option to disable memory pools sharing
Willy Tarreau [Wed, 28 Oct 2015 11:04:02 +0000 (12:04 +0100)] 
DEBUG/MINOR: memory: add a build option to disable memory pools sharing

Sometimes analysing a core file isn't easy due to shared memory pools.
Let's add a build option to disable this. It's not enabled by default,
it could be backported to older versions.

9 years agoMINOR: cli: ability to set per-server maxconn
Andrew Hayworth [Tue, 27 Oct 2015 21:46:25 +0000 (21:46 +0000)] 
MINOR: cli: ability to set per-server maxconn

This commit adds support for setting a per-server maxconn from the stats
socket. The only really notable part of this commit is that we need to
check if maxconn == minconn before changing things, as this indicates
that we are NOT using dynamic maxconn. When we are not using dynamic
maxconn, we should update maxconn/minconn in lockstep.

9 years agoFIX: small typo in an example using the "Referer" header
Cyril Bonté [Mon, 26 Oct 2015 21:37:39 +0000 (22:37 +0100)] 
FIX: small typo in an example using the "Referer" header

It was reported that an example was manipulating a "Referrer" header instead
of the known "Referer" one. Even if it's an example wich doesn't break things,
the typo can be fixed.

The fix should be backported in 1.4/1.5/1.6 branches.

9 years agoDOC: fix a typo for a "deviceatlas" keyword
Cyril Bonté [Mon, 26 Oct 2015 21:37:38 +0000 (22:37 +0100)] 
DOC: fix a typo for a "deviceatlas" keyword

The global keyword 'deviceatlas-properties-cookie' was miswritten.

This typo should also be backported to the 1.6 branch.

9 years agoBUILD: ssl: fix build error introduced in commit 7969a3 with OpenSSL < 1.0.0
Christopher Faulet [Mon, 19 Oct 2015 11:59:24 +0000 (13:59 +0200)] 
BUILD: ssl: fix build error introduced in commit 7969a3 with OpenSSL < 1.0.0

The function 'EVP_PKEY_get_default_digest_nid()' was introduced in OpenSSL
1.0.0. So for older version of OpenSSL, compiled with the SNI support, the
HAProxy compilation fails with the following error:

src/ssl_sock.c: In function 'ssl_sock_do_create_cert':
src/ssl_sock.c:1096:7: warning: implicit declaration of function 'EVP_PKEY_get_default_digest_nid'
   if (EVP_PKEY_get_default_digest_nid(capkey, &nid) <= 0)
[...]
src/ssl_sock.c:1096: undefined reference to `EVP_PKEY_get_default_digest_nid'
collect2: error: ld returned 1 exit status
Makefile:760: recipe for target 'haproxy' failed
make: *** [haproxy] Error 1

So we must add a #ifdef to check the OpenSSL version (>= 1.0.0) to use this
function. It is used to get default signature digest associated to the private
key used to sign generated X509 certificates. It is called when the private key
differs than EVP_PKEY_RSA, EVP_PKEY_DSA and EVP_PKEY_EC. It should be enough for
most of cases.

9 years agoMEDIUM: dns: Don't use the ANY query type
Andrew Hayworth [Mon, 19 Oct 2015 22:29:51 +0000 (22:29 +0000)] 
MEDIUM: dns: Don't use the ANY query type

Basically, it's ill-defined and shouldn't really be used going forward.
We can't guarantee that resolvers will do the 'legwork' for us and
actually resolve CNAMES when we request the ANY query-type. Case in point
(obfuscated, clearly):

  PRODUCTION! ahayworth@secret-hostname.com:~$
  dig @10.11.12.53 ANY api.somestartup.io

  ; <<>> DiG 9.8.4-rpz2+rl005.12-P1 <<>> @10.11.12.53 ANY api.somestartup.io
  ; (1 server found)
  ;; global options: +cmd
  ;; Got answer:
  ;; ->>HEADER<<- opcode: QUERY, status: NOERROR, id: 62454
  ;; flags: qr rd ra; QUERY: 1, ANSWER: 1, AUTHORITY: 4, ADDITIONAL: 0

  ;; QUESTION SECTION:
  ;api.somestartup.io.                        IN      ANY

  ;; ANSWER SECTION:
  api.somestartup.io.         20      IN      CNAME api-somestartup-production.ap-southeast-2.elb.amazonaws.com.

  ;; AUTHORITY SECTION:
  somestartup.io.               166687  IN      NS      ns-1254.awsdns-28.org.
  somestartup.io.               166687  IN      NS      ns-1884.awsdns-43.co.uk.
  somestartup.io.               166687  IN      NS      ns-440.awsdns-55.com.
  somestartup.io.               166687  IN      NS      ns-577.awsdns-08.net.

  ;; Query time: 1 msec
  ;; SERVER: 10.11.12.53#53(10.11.12.53)
  ;; WHEN: Mon Oct 19 22:02:29 2015
  ;; MSG SIZE  rcvd: 242

HAProxy can't handle that response correctly.

Rather than try to build in support for resolving CNAMEs presented
without an A record in an answer section (which may be a valid
improvement further on), this change just skips ANY record types
altogether. A and AAAA are much more well-defined and predictable.

Notably, this commit preserves the implicit "Prefer IPV6 behavior."

Furthermore, ANY query type by default is a bad idea: (from Robin on
HAProxy's ML):
  Using ANY queries for this kind of stuff is considered by most people
  to be a bad practice since besides all the things you named it can
  lead to incomplete responses. Basically a resolver is allowed to just
  return whatever it has in cache when it receives an ANY query instead
  of actually doing an ANY query at the authoritative nameserver. Thus
  if it only received queries for an A record before you do an ANY query
  you will not get an AAAA record even if it is actually available since
  the resolver doesn't have it in its cache. Even worse if before it
  only got MX queries, you won't get either A or AAAA

9 years agoBUG/MAJOR: ssl: free the generated SSL_CTX if the LRU cache is disabled
Willy Tarreau [Tue, 20 Oct 2015 13:16:01 +0000 (15:16 +0200)] 
BUG/MAJOR: ssl: free the generated SSL_CTX if the LRU cache is disabled

Kim Seri reported that haproxy 1.6.0 crashes after a few requests
when a bind line has SSL enabled with more than one certificate. This
was caused by an insufficient condition to free generated certs during
ssl_sock_close() which can also catch other certs.

Christopher Faulet analysed the situation like this :

-------
First the LRU tree is only initialized when the SSL certs generation is
configured on a bind line. So, in the most of cases, it is NULL (it is
not the same thing than empty).
When the SSL certs generation is used, if the cache is not NULL, a such
certificate is pushed in the cache and there is no need to release it
when the connection is closed.
But it can be disabled in the configuration. So in that case, we must
free the generated certificate when the connection is closed.

Then here, we have really a bug. Here is the buggy part:

3125)      if (conn->xprt_ctx) {
3126) #ifdef SSL_CTRL_SET_TLSEXT_HOSTNAME
3127)              if (!ssl_ctx_lru_tree && objt_listener(conn->target)) {
3128)                      SSL_CTX *ctx = SSL_get_SSL_CTX(conn->xprt_ctx);
3129)                      if (ctx != 3130)
 SSL_CTX_free(ctx);
3131)              }
3133)              SSL_free(conn->xprt_ctx);
3134)              conn->xprt_ctx = NULL;
3135)              sslconns--;
3136)      }

The check on the line 3127 is not enough to determine if this is a
generated certificate or not. Because ssl_ctx_lru_tree is NULL,
generated certificates, if any, must be freed. But here ctx should also
be compared to all SNI certificates and not only to default_ctx. Because
of this bug, when a SNI certificate is used for a connection, it is
erroneously freed when this connection is closed.
-------

Christopher provided this reliable reproducer :

----------
global
    tune.ssl.default-dh-param   2048
    daemon

listen ssl_server
    mode tcp
    bind 127.0.0.1:4443 ssl crt srv1.test.com.pem crt srv2.test.com.pem

    timeout connect 5000
    timeout client  30000
    timeout server  30000

    server srv A.B.C.D:80

You just need to generate 2 SSL certificates with 2 CN (here
srv1.test.com and srv2.test.com).

Then, by doing SSL requests with the first CN, there is no problem. But
with the second CN, it should segfault on the 2nd request.

openssl s_client -connect 127.0.0.1:4443 -servername srv1.test.com // OK
openssl s_client -connect 127.0.0.1:4443 -servername srv1.test.com // OK

But,

openssl s_client -connect 127.0.0.1:4443 -servername srv2.test.com // OK
openssl s_client -connect 127.0.0.1:4443 -servername srv2.test.com // KO
-----------

A long discussion led to the following proposal which this patch implements :

- the cert is generated. It gets a refcount = 1.
- we assign it to the SSL. Its refcount becomes two.
- we try to insert it into the tree. The tree will handle its freeing
  using SSL_CTX_free() during eviction.
- if we can't insert into the tree because the tree is disabled, then
  we have to call SSL_CTX_free() ourselves, then we'd rather do it
  immediately. It will more closely mimmick the case where the cert
  is added to the tree and immediately evicted by concurrent activity
  on the cache.
- we never have to call SSL_CTX_free() during ssl_sock_close() because
  the SSL session only relies on openssl doing the right thing based on
  the refcount only.
- thus we never need to know how the cert was created since the
  SSL_CTX_free() is either guaranteed or already done for generated
  certs, and this protects other ones against any accidental call to
  SSL_CTX_free() without having to track where the cert comes from.

This patch also reduces the inter-dependence between the LRU tree and
the SSL stack, so it should cause less sweating to migrate to threads
later.

This bug is specific to 1.6.0, as it was introduced after dev7 by
this fix :

   d2cab92 ("BUG/MINOR: ssl: fix management of the cache where forged certificates are stored")

Thus a backport to 1.6 is required, but not to 1.5.

9 years agoBUG/MEDIUM: namespaces: don't fail if no namespace is used
Willy Tarreau [Tue, 20 Oct 2015 13:14:07 +0000 (15:14 +0200)] 
BUG/MEDIUM: namespaces: don't fail if no namespace is used

Susheel Jalali reported a confusing bug in namespaces implementation.
If namespaces are enabled at build time (USE_NS=1) and *no* namespace
is used at all in the whole config file, my_socketat() returns -1 and
all socket bindings fail. This is because of a wrong condition in this
function. A possible workaround consists in creating some namespaces.

9 years agoBUG/MINOR: dns: parsing error of some DNS response
Baptiste Assmann [Thu, 15 Oct 2015 13:23:28 +0000 (15:23 +0200)] 
BUG/MINOR: dns: parsing error of some DNS response

The function which parses a DNS response buffer did not move properly a
pointer when reading a packet where records does not use DNS "message
compression" techniques.

Thanks to 0yvind Johnsen for the help provided during the troubleshooting
session.

9 years agoCLEANUP: don't ignore debian/ directory if present
Vincent Bernat [Wed, 14 Oct 2015 19:43:58 +0000 (21:43 +0200)] 
CLEANUP: don't ignore debian/ directory if present

This makes packaging with git tools easier as it is not possible to
cancel anything in debian/.gitignore since the whole directory is
ignored.

9 years agoBUILD: install only relevant and existing documentation
Vincent Bernat [Tue, 13 Oct 2015 20:20:55 +0000 (22:20 +0200)] 
BUILD: install only relevant and existing documentation

doc/haproxy-{en,fr}.txt have been removed recently but they were still
referenced in the Makefile. Many other documents have also been
added. Instead of hard-coding a list of documents to install, install
all those in doc/ with some exceptions:

 - coding-style.txt is more for developers
 - gpl.txt and lgpl.txt are usually present at other places (and I would
   have to remove them in the Debian packaging, less work for me)

The documentation in the subdirectories is not installed as it is more
targeted to developers.

9 years agoDOC: specify that stats socket doc (section 9.2) is in management
Kevin Decherf [Tue, 13 Oct 2015 21:26:44 +0000 (23:26 +0200)] 
DOC: specify that stats socket doc (section 9.2) is in management

Commit 44aed90ce102c4136a5eda66d541f6fa79e141e8 moved the stats socket
documentation from config to management but the remaining references to
section 9.2 were not updated; improve it to be less confusing.

Signed-off-by: Kevin Decherf <kevin@kdecherf.com>
9 years ago[RELEASE] Released version 1.7-dev0 v1.7-dev0
Willy Tarreau [Tue, 13 Oct 2015 19:48:10 +0000 (21:48 +0200)] 
[RELEASE] Released version 1.7-dev0

Released version 1.7-dev0 with the following main changes :
    - exact copy of 1.6.0

9 years ago[RELEASE] Released version 1.6.0 v1.6.0
Willy Tarreau [Tue, 13 Oct 2015 16:52:22 +0000 (18:52 +0200)] 
[RELEASE] Released version 1.6.0

Released version 1.6.0 with the following main changes :
    - BUG/MINOR: Handle interactive mode in cli handler
    - DOC: global section missing parameters
    - DOC: backend section missing parameters
    - DOC: stats paramaters available in frontend
    - MINOR: lru: do not allocate useless memory in lru64_lookup
    - BUG/MINOR: http: Add OPTIONS in supported http methods (found by find_http_meth)
    - BUG/MINOR: ssl: fix management of the cache where forged certificates are stored
    - MINOR: ssl: Release Servers SSL context when HAProxy is shut down
    - MINOR: ssl: Read the file used to generate certificates in any order
    - MINOR: ssl: Add support for EC for the CA used to sign generated certificates
    - MINOR: ssl: Add callbacks to set DH/ECDH params for generated certificates
    - BUG/MEDIUM: logs: fix time zone offset format in RFC5424
    - BUILD: Fix the build on OSX (htonll/ntohll)
    - BUILD: enable build on Linux/s390x
    - BUG/MEDIUM: lua: direction test failed
    - MINOR: lua: fix a spelling error in some error messages
    - CLEANUP: cli: ensure we can never double-free error messages
    - BUG/MEDIUM: lua: force server-close mode on Lua services
    - MEDIUM: init: support more command line arguments after pid list
    - MEDIUM: init: support a list of files on the command line
    - MINOR: debug: enable memory poisonning to use byte 0
    - BUILD: ssl: fix build error introduced by recent commit
    - BUG/MINOR: config: make the stats socket pass the correct proxy to the parsers
    - MEDIUM: server: implement TCP_USER_TIMEOUT on the server
    - DOC: mention the "namespace" options for bind and server lines
    - DOC: add the "management" documentation
    - DOC: move the stats socket documentation from config to management
    - MINOR: examples: update haproxy.spec to mention new docs
    - DOC: mention management.txt in README
    - DOC: remove haproxy-{en,fr}.txt
    - BUILD: properly report when USE_ZLIB and USE_SLZ are used together
    - MINOR: init: report use of libslz instead of "no compression"
    - CLEANUP: examples: remove some obsolete and confusing files
    - CLEANUP: examples: remove obsolete configuration file samples
    - CLEANUP: examples: fix the example file content-sw-sample.cfg
    - CLEANUP: examples: update sample file option-http_proxy.cfg
    - CLEANUP: examples: update sample file ssl.cfg
    - CLEANUP: tests: move a test file from examples/ to tests/
    - CLEANUP: examples: shut up warnings in transparent proxy example
    - CLEANUP: tests: removed completely obsolete test files
    - DOC: update ROADMAP to remove what was done in 1.6
    - BUG/MEDIUM: pattern: fixup use_after_free in the pat_ref_delete_by_id

9 years agoDOC: update ROADMAP to remove what was done in 1.6
Willy Tarreau [Tue, 13 Oct 2015 16:38:15 +0000 (18:38 +0200)] 
DOC: update ROADMAP to remove what was done in 1.6

9 years agoBUG/MEDIUM: pattern: fixup use_after_free in the pat_ref_delete_by_id
peter cai [Wed, 7 Oct 2015 07:07:43 +0000 (00:07 -0700)] 
BUG/MEDIUM: pattern: fixup use_after_free in the pat_ref_delete_by_id

I found there is use_after_free bug in the pat_ref_delete_by_id.

[wt: it seems this fix must be backported to 1.5 as well]

9 years agoCLEANUP: tests: removed completely obsolete test files
Willy Tarreau [Tue, 13 Oct 2015 15:07:34 +0000 (17:07 +0200)] 
CLEANUP: tests: removed completely obsolete test files

A number of config files were present in the tests/ directory and which
would either test features that are easier to test using more recent files
or test obsolete features. All of them emit tons of useless warnings, and
instead of fixing them, better remove them since they have never been used
in the last 10 years or so.

The remaining files may still emit warnings and require some fixing but
they provide some value for some tests.

9 years agoCLEANUP: examples: shut up warnings in transparent proxy example
Willy Tarreau [Tue, 13 Oct 2015 13:46:50 +0000 (15:46 +0200)] 
CLEANUP: examples: shut up warnings in transparent proxy example

Just add some missing timeouts.

9 years agoCLEANUP: tests: move a test file from examples/ to tests/
Willy Tarreau [Tue, 13 Oct 2015 13:45:17 +0000 (15:45 +0200)] 
CLEANUP: tests: move a test file from examples/ to tests/

examples are for users, tests are for developers.

9 years agoCLEANUP: examples: update sample file ssl.cfg
Willy Tarreau [Tue, 13 Oct 2015 13:44:31 +0000 (15:44 +0200)] 
CLEANUP: examples: update sample file ssl.cfg

This one emitted an error due to the lack of "verify none" on the server line.

9 years agoCLEANUP: examples: update sample file option-http_proxy.cfg
Willy Tarreau [Tue, 13 Oct 2015 13:43:39 +0000 (15:43 +0200)] 
CLEANUP: examples: update sample file option-http_proxy.cfg

This one was still valid but emitted lots of warnings.

9 years agoCLEANUP: examples: fix the example file content-sw-sample.cfg
Willy Tarreau [Tue, 13 Oct 2015 13:38:46 +0000 (15:38 +0200)] 
CLEANUP: examples: fix the example file content-sw-sample.cfg

This one didn't load anymore, but it was worth updating it since it matches
most common needs.

9 years agoCLEANUP: examples: remove obsolete configuration file samples
Willy Tarreau [Tue, 13 Oct 2015 13:22:59 +0000 (15:22 +0200)] 
CLEANUP: examples: remove obsolete configuration file samples

This removes the obsolete CTTPROXY configuration, the tarpit example,
and the pre-content switching example involving 3 layers and cookie
rewriting to emulate the use_backend feature... (9 years old).

9 years agoCLEANUP: examples: remove some obsolete and confusing files
Willy Tarreau [Tue, 13 Oct 2015 13:15:10 +0000 (15:15 +0200)] 
CLEANUP: examples: remove some obsolete and confusing files

Some files are totally obsolete. The Formilux init scripts and packaging
scripts for haproxy 1.1.21 should go. Linux 2.4 kernel patch to enable
epoll() on EOLed RHEL3 should go. The tuning script is incomplete and
only suited to older kernels, better stop shipping this one.

9 years agoMINOR: init: report use of libslz instead of "no compression"
Willy Tarreau [Tue, 13 Oct 2015 14:46:28 +0000 (16:46 +0200)] 
MINOR: init: report use of libslz instead of "no compression"

It's confusing to see "no zlib support" followed by supported
compression algorithms. Fix this.

9 years agoBUILD: properly report when USE_ZLIB and USE_SLZ are used together
Willy Tarreau [Tue, 13 Oct 2015 14:45:21 +0000 (16:45 +0200)] 
BUILD: properly report when USE_ZLIB and USE_SLZ are used together

Use #error here otherwise the errors are hard to spot for the casual
user.

9 years agoDOC: remove haproxy-{en,fr}.txt
Willy Tarreau [Tue, 13 Oct 2015 14:34:46 +0000 (16:34 +0200)] 
DOC: remove haproxy-{en,fr}.txt

This long-awaited moment finally came!

9 years agoDOC: mention management.txt in README
Willy Tarreau [Tue, 13 Oct 2015 14:32:20 +0000 (16:32 +0200)] 
DOC: mention management.txt in README

and in intro.txt as well. Remove references to haproxy-{en,fr}.txt.

9 years agoMINOR: examples: update haproxy.spec to mention new docs
Willy Tarreau [Tue, 13 Oct 2015 14:33:57 +0000 (16:33 +0200)] 
MINOR: examples: update haproxy.spec to mention new docs

intro.txt and management.txt were added. haproxy-{en,fr}.txt were removed.

9 years agoDOC: move the stats socket documentation from config to management
Willy Tarreau [Tue, 13 Oct 2015 12:45:29 +0000 (14:45 +0200)] 
DOC: move the stats socket documentation from config to management

The documentation of the stats part is much more related to management
than to the configuration, move it there.

9 years agoDOC: add the "management" documentation
Willy Tarreau [Tue, 13 Oct 2015 12:40:55 +0000 (14:40 +0200)] 
DOC: add the "management" documentation

This doc explains how to start/stop haproxy, what signals are used
and a few debugging tricks. It's far from being complete but should
already help a number of users.

The stats part will be taken from the config doc.

9 years agoDOC: mention the "namespace" options for bind and server lines
Willy Tarreau [Tue, 13 Oct 2015 12:50:22 +0000 (14:50 +0200)] 
DOC: mention the "namespace" options for bind and server lines

It was only in the network-namespaces doc, but it needs to be
present in the config doc as well.

9 years agoMEDIUM: server: implement TCP_USER_TIMEOUT on the server
Willy Tarreau [Tue, 13 Oct 2015 14:16:41 +0000 (16:16 +0200)] 
MEDIUM: server: implement TCP_USER_TIMEOUT on the server

This is equivalent to commit 2af207a ("MEDIUM: tcp: implement tcp-ut
bind option to set TCP_USER_TIMEOUT") except that this time it works
on the server side. The purpose is to detect dead server connections
even when checks are rare, disabled, or after a soft reload (since
checks are disabled there as well), and to ensure client connections
will get killed faster.

9 years agoBUG/MINOR: config: make the stats socket pass the correct proxy to the parsers
Willy Tarreau [Tue, 13 Oct 2015 13:06:57 +0000 (15:06 +0200)] 
BUG/MINOR: config: make the stats socket pass the correct proxy to the parsers

Baptiste reported a segfault when the "id" keyword was passed on the
"stats socket" line. The problem is related to the fact that the stats
parser stats_parse_global() passes curpx instead of global.stats_fe to
the keyword parser. Indeed, curpx being a pointer to the proxy in the
current section, it is not correct here since the global section does
not describe a proxy. It's just by pure luck that only bind_parse_id()
uses the proxy since any other keyword parser could use it as well.

The bug has no impact since the id specified here is not usable at all
and can be discarded from a faulty configuration.

This fix must be backported to 1.5.

9 years agoBUG/MEDIUM: lua: direction test failed
Thierry FOURNIER [Tue, 13 Oct 2015 12:25:11 +0000 (14:25 +0200)] 
BUG/MEDIUM: lua: direction test failed

Lua needs to known the direction of the http data processed (request or
response). It checks the flag SMP_OPT_DIR_REQ, buf this flag is 0. This patch
correctly checks the flags after applying the SMP_OPT_DIR mask.

9 years agoDOC: stats paramaters available in frontend
Baptiste Assmann [Mon, 12 Oct 2015 18:30:24 +0000 (20:30 +0200)] 
DOC: stats paramaters available in frontend

All stats directive are now available in both frontend and backend
sections.

9 years agoDOC: backend section missing parameters
Baptiste Assmann [Mon, 12 Oct 2015 18:22:55 +0000 (20:22 +0200)] 
DOC: backend section missing parameters

One parameter was missing in the proxy paramater list.
One parameter was not alphabeticaly sorted.

9 years agoDOC: global section missing parameters
Baptiste Assmann [Mon, 12 Oct 2015 18:21:23 +0000 (20:21 +0200)] 
DOC: global section missing parameters

Some parameters were missing in the global paramater list.
A few parameters were not alphabeticaly sorted.

9 years agoBUILD: enable build on Linux/s390x
Neale Ferguson [Mon, 12 Oct 2015 18:58:51 +0000 (20:58 +0200)] 
BUILD: enable build on Linux/s390x

I would like to contribute the following fix to enable the Linux s390x
platform. The fix was built against today's git master. I've attached the
patch for review. Depending on your buildbot/jenkins/? requirements I can
set up a virtual machine for automated building/testing of the package in
this environment.

9 years agoBUG/MINOR: Handle interactive mode in cli handler
Andrew Hayworth [Fri, 2 Oct 2015 15:08:10 +0000 (15:08 +0000)] 
BUG/MINOR: Handle interactive mode in cli handler

A previous commit broke the interactive stats cli prompt. Specifically,
it was not clear that we could be in STAT_CLI_PROMPT when we get to
the output functions for the cli handler, and the switch statement did
not handle this case. We would then fall through to the default
statement, which was recently changed to set error flags on the socket.
This in turn causes the socket to be closed, which is not what we wanted
in this specific case.

To fix, we add a case for STAT_CLI_PROMPT, and simply break out of the
switch statement.

Testing:
 - Connected to unix stats socket, issued 'prompt', observed that I
   could issue multiple consecutive commands.
 - Connected to unix stats socket, issued 'prompt', observed that socket
   timed out after inactivity expired.
 - Connected to unix stats socket, issued 'prompt' then 'set timeout cli
   5', observed that socket timed out after 5 seconds expired.
 - Connected to unix stats socket, issued invalid commands, received
   usage output.
 - Connected to unix stats socket, issued 'show info', received info
   output and socket disconnected.
 - Connected to unix stats socket, issued 'show stat', received stats
   output and socket disconnected.
 - Repeated above tests with TCP stats socket.

[wt: no backport needed, this was introduced during the applet rework in 1.6]

9 years agoMINOR: lua: fix a spelling error in some error messages
Vincent Bernat [Tue, 6 Oct 2015 14:05:59 +0000 (16:05 +0200)] 
MINOR: lua: fix a spelling error in some error messages

"unknown" was spelled "unkown".

9 years agoBUG/MEDIUM: logs: fix time zone offset format in RFC5424
Dragan Dosen [Fri, 9 Oct 2015 19:31:43 +0000 (21:31 +0200)] 
BUG/MEDIUM: logs: fix time zone offset format in RFC5424

The time zone offset format used in function update_log_hdr_rfc5424() was
missing ":" as a separator.

9 years agoMINOR: ssl: Add callbacks to set DH/ECDH params for generated certificates
Christopher Faulet [Fri, 9 Oct 2015 09:46:32 +0000 (11:46 +0200)] 
MINOR: ssl: Add callbacks to set DH/ECDH params for generated certificates

Now, A callback is defined for generated certificates to set DH parameters for
ephemeral key exchange when required.
In same way, when possible, we also defined Elliptic Curve DH (ECDH) parameters.

9 years agoMINOR: ssl: Add support for EC for the CA used to sign generated certificates
Christopher Faulet [Fri, 9 Oct 2015 09:15:03 +0000 (11:15 +0200)] 
MINOR: ssl: Add support for EC for the CA used to sign generated certificates

This is done by adding EVP_PKEY_EC type in supported types for the CA private
key when we get the message digest used to sign a generated X509 certificate.
So now, we support DSA, RSA and EC private keys.

And to be sure, when the type of the private key is not directly supported, we
get its default message digest using the function
'EVP_PKEY_get_default_digest_nid'.

We also use the key of the default certificate instead of generated it. So we
are sure to use the same key type instead of always using a RSA key.

9 years agoMINOR: ssl: Read the file used to generate certificates in any order
Christopher Faulet [Fri, 9 Oct 2015 08:53:31 +0000 (10:53 +0200)] 
MINOR: ssl: Read the file used to generate certificates in any order

the file specified by the SSL option 'ca-sign-file' can now contain the CA
certificate used to dynamically generate certificates and its private key in any
order.

9 years agoBUILD: ssl: fix build error introduced by recent commit
Willy Tarreau [Fri, 9 Oct 2015 10:10:13 +0000 (12:10 +0200)] 
BUILD: ssl: fix build error introduced by recent commit

Commit d2cab92 ("BUG/MINOR: ssl: fix management of the cache where forged
certificates are stored") removed some needed #ifdefs resulting in ssl not
building on older openssl versions where SSL_CTRL_SET_TLSEXT_HOSTNAME is
not defined :

src/ssl_sock.c: In function 'ssl_sock_load_ca':
src/ssl_sock.c:2504: error: 'ssl_ctx_lru_tree' undeclared (first use in this function)
src/ssl_sock.c:2504: error: (Each undeclared identifier is reported only once
src/ssl_sock.c:2504: error: for each function it appears in.)
src/ssl_sock.c:2505: error: 'ssl_ctx_lru_seed' undeclared (first use in this function)
src/ssl_sock.c: In function 'ssl_sock_close':
src/ssl_sock.c:3095: error: 'ssl_ctx_lru_tree' undeclared (first use in this function)
src/ssl_sock.c: In function '__ssl_sock_deinit':
src/ssl_sock.c:5367: error: 'ssl_ctx_lru_tree' undeclared (first use in this function)
make: *** [src/ssl_sock.o] Error 1

Reintroduce the ifdefs around the faulty areas.

9 years agoMINOR: ssl: Release Servers SSL context when HAProxy is shut down
Christopher Faulet [Wed, 29 Jul 2015 11:02:40 +0000 (13:02 +0200)] 
MINOR: ssl: Release Servers SSL context when HAProxy is shut down

[wt: could be backported to 1.5 as well]

9 years agoBUG/MINOR: ssl: fix management of the cache where forged certificates are stored
Christopher Faulet [Tue, 28 Jul 2015 14:03:47 +0000 (16:03 +0200)] 
BUG/MINOR: ssl: fix management of the cache where forged certificates are stored

First, the LRU cache must be initialized after the configuration parsing to
correctly set its size.
Next, the function 'ssl_sock_set_generated_cert' returns -1 when an error occurs
(0 if success). In that case, the caller is responsible to free the memory
allocated for the certificate.
Finally, when a SSL certificate is generated by HAProxy but cannot be inserted
in the cache, it must be freed when the SSL connection is closed. This happens
when 'tune.ssl.ssl-ctx-cache-size' is set to 0.

9 years agoBUG/MINOR: http: Add OPTIONS in supported http methods (found by find_http_meth)
Christopher Faulet [Fri, 31 Jul 2015 12:26:57 +0000 (14:26 +0200)] 
BUG/MINOR: http: Add OPTIONS in supported http methods (found by find_http_meth)

The 'OPTIONS' method was not in the list of supported HTTP methods and
find_http_meth return HTTP_METH_OTHER instead of HTTP_METH_OPTIONS.

[wt: this fix needs to be backported at least to 1.5, 1.4 and 1.3]

9 years agoMINOR: lru: do not allocate useless memory in lru64_lookup
Christopher Faulet [Tue, 28 Jul 2015 14:01:07 +0000 (16:01 +0200)] 
MINOR: lru: do not allocate useless memory in lru64_lookup

lru64_lookup function was added in a previous patch of mine. This one
just remove a useless memory allocation.

9 years agoBUILD: Fix the build on OSX (htonll/ntohll)
Joseph Lynch [Wed, 7 Oct 2015 02:43:18 +0000 (19:43 -0700)] 
BUILD: Fix the build on OSX (htonll/ntohll)

htonll and ntohll were defined in 5b4dd683cb but on osx they are already
defined in sys/_endian.h. So, we check if they are defined before
declaring them.

[wt: no backport needed]

9 years agoMINOR: debug: enable memory poisonning to use byte 0
Willy Tarreau [Thu, 8 Oct 2015 12:12:13 +0000 (14:12 +0200)] 
MINOR: debug: enable memory poisonning to use byte 0

When debugging an issue, sometimes it can be useful to be able to use
byte 0 to poison memory areas, resulting in the same effect as a calloc().
This patch changes the default mem_poison_byte to -1 to disable it so that
all positive values are usable.

9 years agoMEDIUM: init: support a list of files on the command line
Willy Tarreau [Thu, 8 Oct 2015 09:58:48 +0000 (11:58 +0200)] 
MEDIUM: init: support a list of files on the command line

HAProxy could already support being passed a file list on the command
line, by passing multiple times "-f" followed by a file name. People
have been complaining that it made it hard to pass file lists from init
scripts.

This patch introduces an end of arguments using the common "--" tag,
after which only file names may appear. These files are then added to
the existing list of other files specified using -f and are loaded in
their declaration order. Thus it becomes possible to do something like
this :

    haproxy -sf $(pidof haproxy) -- /etc/haproxy/global.cfg /etc/haproxy/customers/*.cfg

9 years agoMEDIUM: init: support more command line arguments after pid list
Willy Tarreau [Thu, 8 Oct 2015 09:32:32 +0000 (11:32 +0200)] 
MEDIUM: init: support more command line arguments after pid list

Given that all command line arguments start with a '-' and that
no pid number can start with this character, there's no constraint
to make the pid list the last argument. Let's relax this rule.

9 years agoBUG/MEDIUM: lua: force server-close mode on Lua services
Willy Tarreau [Wed, 7 Oct 2015 18:20:28 +0000 (20:20 +0200)] 
BUG/MEDIUM: lua: force server-close mode on Lua services

Thierry reported that keep-alive still didn't cope well with Lua
services. The reason is that for now applets have to be closed at
the end of a transaction so we want to work in server-close mode,
which isn't noticeable by the client since it still sees keep-alive.
Additionally we want to enable the request body transfer analyser
which will be needed to synchronize with the response analyser to
indicate the end of the transfer.

9 years agoCLEANUP: cli: ensure we can never double-free error messages
Willy Tarreau [Wed, 7 Oct 2015 18:00:24 +0000 (20:00 +0200)] 
CLEANUP: cli: ensure we can never double-free error messages

The release handler used to be called twice for some time and just by
pure luck we never ended up double-freeing the data there. Add a NULL
to ensure this can never happen should a future change permit this
situation again.

9 years ago[RELEASE] Released version 1.6-dev7 v1.6-dev7
Willy Tarreau [Tue, 6 Oct 2015 10:13:56 +0000 (12:13 +0200)] 
[RELEASE] Released version 1.6-dev7

Released version 1.6-dev7 with the following main changes :
    - MINOR: cli: Dump all resolvers stats if no resolver section is given
    - BUG: config: external-check command validation is checking for incorrect arguments.
    - DOC: documentation format cleanups
    - DOC: lua: few typos.
    - BUG/MEDIUM: str2ip: make getaddrinfo() consider local address selection policy
    - BUG/MEDIUM: logs: segfault writing to log from Lua
    - DOC: fix lua use-service example
    - MINOR: payload: add support for tls session ticket ext
    - MINOR: lua: remove the run flag
    - MEDIUM: lua: change the timeout execution
    - MINOR: lua: rename the tune.lua.applet-timeout
    - DOC: lua: update Lua doc
    - DOC: lua: update doc according with the last Lua changes
    - MINOR: http/tcp: fill the avalaible actions
    - DOC: reorder misplaced res.ssl_hello_type in the doc
    - BUG/MINOR: tcp: make silent-drop always force a TCP reset
    - CLEANUP: tcp: silent-drop: only drain the connection when quick-ack is disabled
    - BUILD: tcp: use IPPROTO_IP when SOL_IP is not available
    - BUILD: server: fix build warnings introduced by load-server-state
    - BUG/MEDIUM: server: fix misuse of format string in load-server-state's warnings

9 years agoMINOR: cli: Dump all resolvers stats if no resolver section is given
Andrew Hayworth [Fri, 2 Oct 2015 20:33:01 +0000 (20:33 +0000)] 
MINOR: cli: Dump all resolvers stats if no resolver section is given

This commit adds support for dumping all resolver stats. Specifically
if a command 'show stats resolvers' is issued withOUT a resolver section
id, we dump all known resolver sections. If none are configured, a
message is displayed indicating that.

9 years agoBUG: config: external-check command validation is checking for incorrect arguments.
Ben Cabot [Wed, 16 Sep 2015 11:07:51 +0000 (12:07 +0100)] 
BUG: config: external-check command validation is checking for incorrect arguments.

When using the external-check command option HAProxy was failing to
start with a fatal error "'external-check' cannot handle unexpected
argument". When looking at the code it was looking for an incorrect
argument. Also correcting an Alert message text as spotted by by
PiBa-NL.

9 years agoDOC: lua: few typos.
David Carlier [Fri, 2 Oct 2015 10:59:38 +0000 (11:59 +0100)] 
DOC: lua: few typos.

9 years agoMINOR: http/tcp: fill the avalaible actions
Thierry FOURNIER [Fri, 2 Oct 2015 06:24:51 +0000 (08:24 +0200)] 
MINOR: http/tcp: fill the avalaible actions

This patch adds a function that generates the list of avalaible actions
for the error message.