milktoasthoney/master/haproxy.cfg

119 lines
3.5 KiB
INI

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