global log /dev/log local0 log /dev/log local1 notice chroot /var/lib/haproxy stats socket /run/haproxy/admin.sock mode 660 level admin expose-fd listeners stats timeout 30s user haproxy group haproxy daemon # Default SSL material locations ca-base /etc/ssl/certs crt-base /etc/ssl/private # See: https://ssl-config.mozilla.org/#server=haproxy&server-version=2.0.3&config=intermediate ssl-default-bind-ciphers ECDHE-ECDSA-AES128-GCM-SHA256:ECDHE-RSA-AES128-GCM-SHA256:ECDHE-ECDSA-AES256-GCM-SHA384:ECDHE-RSA-AES256-GCM-SHA384:ECDHE-ECDSA-CHACHA20-POLY1305:ECDHE-RSA-CHACHA20-POLY1305:DHE-RSA-AES128-GCM-SHA256:DHE-RSA-AES256-GCM-SHA384 ssl-default-bind-ciphersuites TLS_AES_128_GCM_SHA256:TLS_AES_256_GCM_SHA384:TLS_CHACHA20_POLY1305_SHA256 ssl-default-bind-options ssl-min-ver TLSv1.2 no-tls-tickets defaults log global mode http option httplog option dontlognull timeout connect 5000 timeout client 50000 timeout server 50000 errorfile 400 /etc/haproxy/errors/400.http errorfile 403 /etc/haproxy/errors/403.http errorfile 408 /etc/haproxy/errors/408.http errorfile 500 /etc/haproxy/errors/500.http errorfile 502 /etc/haproxy/errors/502.http errorfile 503 /etc/haproxy/errors/503.http errorfile 504 /etc/haproxy/errors/504.http frontend http-in bind :80 alpn h2,http/1.1 bind :8008 alpn h2,http/1.1 bind :443 ssl crt /certs/.acme.sh/rato.ro.eu.org/all.pem alpn h2,http/1.1 bind :8448 ssl crt /certs/.acme.sh/rato.ro.eu.org/all.pem alpn h2,http/1.1 default_backend matrix use_backend aaa if { hdr_beg(host) -i aaa } use_backend matrixwellknown if { path -i -m beg /.well-known/matrix } use_backend dimension if { hdr_beg(host) -i dimension } use_backend element if { hdr_beg(host) -i element } use_backend fosstodon if { hdr_beg(host) -i fosstodon } use_backend jitsi if { hdr_beg(host) -i jitsi } use_backend keycloak if { hdr_beg(host) -i keycloak } use_backend revolt if { hdr_beg(host) -i revolt. } use_backend revolt-api if { hdr_beg(host) -i revolt-api } use_backend revolt-ws if { hdr_beg(host) -i revolt-ws } use_backend revolt-au if { hdr_beg(host) -i revolt-au } use_backend revolt-jan if { hdr_beg(host) -i revolt-jan } use_backend revolt-vox if { hdr_beg(host) -i revolt-vox } use_backend site if { hdr_beg(host) -i site } use_backend h2 if { hdr_beg(host) -i h2 } use_backend pad if { hdr_beg(host) -i pad } use_backend wiki if { hdr_beg(host) -i wiki } backend aaa server aaa 10.255.253.199:80 backend jitsi server jitsi 10.255.253.196:80 backend keycloak server keycloak 10.255.253.198:8080 backend matrix server matrix 10.255.253.10:8008 backend matrixwellknown http-response add-header Access-Control-Allow-Origin * option forwardfor server matrixwellknown 10.255.253.14:80 backend dimension http-response add-header Access-Control-Allow-Origin * option forwardfor server dimension 10.255.253.13:8184 backend element server element 10.255.253.12:80 backend fosstodon server fosstodon 10.255.253.20:3001 backend revolt server revolt 10.255.253.30:5000 backend revolt-api server revolt-api 10.255.253.31:8000 backend revolt-ws server revolt-ws 10.255.253.31:9000 backend revolt-au server revolt-au 10.255.253.32:3000 backend revolt-jan server revolt-jan 10.255.253.33:3000 backend revolt-vox server revolt-vox 10.255.253.34:8080 backend wiki server wiki 10.255.253.194:80 backend site server site 10.255.253.40:80 backend pad server pad 10.255.253.50:3000 backend h2 server h2 10.255.253.60:3000