# /etc/nginx/sites-available/mainsail map $http_upgrade $connection_upgrade { default upgrade; '' close; } upstream apiserver { ip_hash; server {{ mainsail_api_server }}; } server { listen 80 ; server_name {{ mainsail_domain }}; access_log /var/log/nginx/mainsail-access.log; error_log /var/log/nginx/mainsail-error.log; # disable this section on smaller hardware like a pi zero gzip on; gzip_vary on; gzip_proxied any; gzip_proxied expired no-cache no-store private auth; gzip_comp_level 4; gzip_buffers 16 8k; gzip_http_version 1.1; gzip_types text/plain text/css text/xml text/javascript application/javascript application/x-javascript application/json application/xml; # web_path from mainsail static files root {{ mainsail_dir }}; index index.html; # disable max upload size checks client_max_body_size 0; # disable proxy request buffering proxy_request_buffering off; location / { try_files $uri $uri/ /index.html; } location = /index.html { add_header Cache-Control "no-store, no-cache, must-revalidate"; } location /websocket { proxy_pass http://apiserver/websocket; proxy_http_version 1.1; proxy_set_header Upgrade $http_upgrade; proxy_set_header Connection $connection_upgrade; 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_read_timeout 86400; } location ~ ^/(printer|api|access|machine|server)/ { proxy_pass http://apiserver$request_uri; 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-Scheme $scheme; } }