I use my pfSense with ACME and HAProxy extensions to manage and auto-renew certificates as well as having a reverse proxy with load balancing capabilities. In my ACME module I define my domains to challenge for like so:
data:image/s3,"s3://crabby-images/9e9dd/9e9dd24171617a131c86f3af2445ac95b35266c2" alt="In my domain SAN list I have my enabled domain with the method type 'Standalone HTTP server'."
This means once my certificate will be re-newed, a standalone HTTP server will be launched that will listen on port 80. The 'well known acme challenge' files will be reached on such server and my certificate will be validated.
Now I'd like to redirect all HTTP traffic to HTTPS in the reverse proxy (HAProxy frontend) of pfSense. For this, I could setup a new frontend that listens on the WAN address on port 80 in the HAProxy module that will redirect if the path does not start with /.well-known/acme-challenge/
like so:
data:image/s3,"s3://crabby-images/1a9c1/1a9c1d52be66d6e359e99da6ac0ad3e6bab27bdc" alt="In the Access Control List (ACL) I define a rule called "acme" with the expression "Path starts with" and the value /.well-known/acme-challenge/. In the Actions table I would add the action http_request redirect with the child Action rule: scheme https for the condition acl names !acme."
So if the path starts with /.well-known/acme-challenge/
, no redirect will occur, but if not, the HTTP request will respond with a Location header to the HTTPS version of the requested URL. The ACL conditioning works so far, but my problem is that HAProxy will now return "503 Service Unavailable - No server is available to handle this request." when I request anything within /.well-known/acme-challenge/
.
This is obvious: HAProxy started to listen on the port 80 of the WAN address, so my Standalone HTTP server gets shadowed by it. HAProxy can only return error 503 as it doesn't know what pfSense itself would do with such request.
What I think I need to do is to setup a backend that I send the request to, if the request's path starts with /.well-known/acme-challenge/
, but how do I have to setup such backend in HAProxy, so it works with the Standalone HTTP server of the ACME module?
I've tried to add a backend for 127.0.0.1:80
as well as the IP of my host on port 80. I then added another Action on my frontend in HAProxy with the Condition acl names acme
to such backend, but I still get error 503 and this is not due to the fact that my standalone server is not running yet. I get the same error when I try to run the ACME challenge with the Let's Encrypt Staging Environment.
[data:image/s3,"s3://crabby-images/6e659/6e6590b9fa83de0fc4b370b85e8015f7fe936f65" alt="The log says: Verifving; Standalone mode server; Pending, The CA is processing your order, please just wait. (1/30); socat989891 E write(6, 0x800add000, 39): Broken pipe
scat!209211 E write(6. 0x800add000. 126): Broken pipe
.com:Verify error:...: Invalid response from http://.../.well-known/acme-challenge/..."
data:image/s3,"s3://crabby-images/fd14f/fd14f7cd9378535bfaa29c696546655bfdb9e28c" alt="In one example my default HAProxy Backend has 192.168.0.1:80 in its server list (IP of PfSense in the LAN)."
data:image/s3,"s3://crabby-images/7522e/7522e59eda5e0b7e51d44d951f5b3b33e273ba14" alt="The redirection of ACME requests to the backend are put in the first row in the action table of the frontend."
How can I make the ACME Standalone HTTP server as well as my HTTP to HTTPS redirection co-exist without any problems?