# Gitea vhost with Let's Encrypt (Certbot) # Managed by Ansible - DO NOT EDIT MANUALLY server { listen 80; server_name {{ gitea_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 {{ gitea_nginx_hostname }}; # Let's Encrypt certificates (managed by Certbot) ssl_certificate /etc/letsencrypt/live/{{ gitea_nginx_hostname }}/fullchain.pem; ssl_certificate_key /etc/letsencrypt/live/{{ gitea_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_gitea; error_log syslog:server=unix:/dev/log,nohostname,tag=nginx_gitea; {% else %} access_log /var/log/nginx/{{ gitea_nginx_hostname }}_access.log main; error_log /var/log/nginx/{{ gitea_nginx_hostname }}_error.log; {% endif %} # Increase client max body size for large Git pushes client_max_body_size 512M; location / { proxy_pass http://127.0.0.1:{{ gitea_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; # Required for Git LFS and large repository operations proxy_buffering off; proxy_request_buffering off; } }