MEDIUM: httpclient/ssl: verify required
The httpclient HTTPS requests now enable the "verify required" option.
To achieve this, the "@system-ca" ca-file is configured in the
httpclient ssl server. Which means all the system CAs will be loaded at
haproxy startup.
diff --git a/src/http_client.c b/src/http_client.c
index 0e96217..60d05e6 100644
--- a/src/http_client.c
+++ b/src/http_client.c
@@ -15,6 +15,7 @@
#include <haproxy/api.h>
#include <haproxy/applet.h>
#include <haproxy/cli.h>
+#include <haproxy/ssl_ckch.h>
#include <haproxy/dynbuf.h>
#include <haproxy/cfgparse.h>
#include <haproxy/conn_stream.h>
@@ -1039,7 +1040,11 @@
if (!httpclient_srv_ssl->id)
goto err;
- httpclient_srv_ssl->ssl_ctx.verify = SSL_SOCK_VERIFY_NONE;
+ httpclient_srv_ssl->ssl_ctx.verify = SSL_SOCK_VERIFY_REQUIRED;
+ httpclient_srv_ssl->ssl_ctx.ca_file = strdup("@system-ca");
+ if (!ssl_store_load_locations_file(httpclient_srv_ssl->ssl_ctx.ca_file, 1, CAFILE_CERT))
+ goto err;
+
#endif
/* add the proxy in the proxy list only if everything is successful */