Files
nix-flakes/modules/nginx/sites-available/forsen-cock.dedyn.io
2025-07-23 16:47:48 +03:00

83 lines
2.7 KiB
Io

server {
listen 80;
server_name forsen-cock.dedyn.io;
return 301 https://$host$request_uri;
}
server {
listen 443 ssl http2;
listen [::]:443 ssl http2;
server_name forsen-cock.dedyn.io;
access_log /var/log/nginx/forsen-cock.access.log;
error_log /var/log/nginx/forsen-cock.error.log;
ssl_certificate /etc/letsencrypt/live/forsen-cock.dedyn.io/fullchain.pem;
ssl_certificate_key /etc/letsencrypt/live/forsen-cock.dedyn.io/privkey.pem;
ssl_protocols TLSv1.2 TLSv1.3;
ssl_prefer_server_ciphers on;
ssl_ciphers HIGH:!aNULL:!MD5;
# Serve static files (optional)
root /var/www/forsen-cock.dedyn.io;
index index.html index.htm;
# Optional root tuwunel page ("hewwo from tuwunel woof!")
# location = / {
# proxy_pass http://127.0.0.1:8448$request_uri;
# proxy_set_header Host $host;
# proxy_set_header X-Real-IP $remote_addr;
# proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
# proxy_set_header X-Forwarded-Proto $scheme;
# proxy_buffering off;
# client_max_body_size 20M;
# proxy_read_timeout 300s;
# }
# Core Matrix APIs (Client-Server and Server-Server)
location ^~ /_matrix/ {
proxy_pass http://127.0.0.1:8448;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto $scheme;
proxy_buffering off;
client_max_body_size 20M;
proxy_read_timeout 300s;
}
# Tuwunel-specific routes
location ^~ /_tuwunel/ {
proxy_pass http://127.0.0.1:8448;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto $scheme;
proxy_buffering off;
client_max_body_size 20M;
proxy_read_timeout 300s;
}
# Optional: Federation delegation
location = /.well-known/matrix/server {
default_type application/json;
add_header Access-Control-Allow-Origin *;
return 200 '{"m.server":"forsen-cock.dedyn.io:443"}';
}
# Optional: Client discovery
location = /.well-known/matrix/client {
default_type application/json;
add_header Access-Control-Allow-Origin *;
return 200 '{"m.homeserver":{"base_url":"https://forsen-cock.dedyn.io"}}';
}
# Optional: Support contact
location = /.well-known/matrix/support {
default_type application/json;
add_header Access-Control-Allow-Origin *;
return 200 '{"support":{"email":"amoelle@forsen-cock.dedyn.io"}}';
}
}