# Uptime Kuma vhost with Let's Encrypt (Certbot) # Managed by Ansible - DO NOT EDIT MANUALLY server { listen 80; server_name {{ uptime_kuma_nginx_hostname }}; # Certbot webroot for ACME challenges location /.well-known/acme-challenge/ { root /var/www/certbot; } # Redirect to HTTPS location / { return 301 https://$server_name$request_uri; } } server { listen 443 ssl; server_name {{ uptime_kuma_nginx_hostname }}; # Let's Encrypt certificates (managed by Certbot) ssl_certificate /etc/letsencrypt/live/{{ uptime_kuma_nginx_hostname }}/fullchain.pem; ssl_certificate_key /etc/letsencrypt/live/{{ uptime_kuma_nginx_hostname }}/privkey.pem; # SSL configuration ssl_protocols {{ nginx_ssl_protocols | default('TLSv1.3') }}; ssl_prefer_server_ciphers on; {% if nginx_log_backend | default('journald') == 'journald' %} access_log syslog:server=unix:/dev/log,nohostname,tag=nginx_uptime_kuma; error_log syslog:server=unix:/dev/log,nohostname,tag=nginx_uptime_kuma; {% else %} access_log /var/log/nginx/{{ uptime_kuma_nginx_hostname }}_access.log main; error_log /var/log/nginx/{{ uptime_kuma_nginx_hostname }}_error.log; {% endif %} location / { proxy_pass http://127.0.0.1:{{ uptime_kuma_port }}; proxy_set_header Host $http_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; # WebSocket support for real-time updates proxy_http_version 1.1; proxy_set_header Upgrade $http_upgrade; proxy_set_header Connection "upgrade"; # Disable buffering for real-time updates proxy_buffering off; } }