Recently I changed my nginx configuration to support Client Certificates to login in to services through the Web from outside my internal network. This will be broken down in to mutable parts so that it is easier to read.

If you have not created you Client Certificate see Part 1.

  • Creating Client Certificates
  • Configuring Haproxy to accept them
  • Configuring Haproxy to reverse proxy to your web applications
  • Adding your Client Certificate to your browser

Configuring Haproxy to Accept Client Certificates

This part is actually pretty easy assuming that you have ssl enabled on the connection you only need to add 3 lines.

frontend external-https
    bind *:443 ssl crt /etc/haproxy/certs/generalzero.org.pem ca-file /etc/haproxy/certs/client.crt verify optional crt-ignore-err all

Thats it.

Configuring Haproxy to reverse proxy to your web applications

Now we can configure the Reverse Proxy to validate certificates before going to the internal services.

	acl cert-acl url_beg /cerrt AND if { ssl_fc_has_crt }
	use_backend cert if cert-acl

You can also make it so that you can have another site when ssl_client is not verified like this

backend cert
    server cert-server 127.0.0.1:8181 check

Continue to the next Part 3