upstream frappe-bench-frappe { server 127.0.0.1:8000 fail_timeout=0; } upstream frappe-bench-socketio-server { server 127.0.0.1:9000 fail_timeout=0; } # setup maps map $host $site_name_bbjfslw { riwollis-box.tcp4.me riwollis-box.tcp4.me; riwollis-shop.tcp4.me riwollis-shop.tcp4.me; riwollis-shop.tcp4 riwollis-shop.tcp4.me; default $host; } # server blocks server { listen 80; server_name riwollis-box.tcp4.me riwollis-shop.tcp4.me riwollis-shop.tcp4.me ; root /disk/service/web/home/erp/frappe-bench/sites; add_header X-Frame-Options "SAMEORIGIN"; add_header Strict-Transport-Security "max-age=63072000; includeSubDomains; preload"; add_header X-Content-Type-Options nosniff; add_header X-XSS-Protection "1; mode=block"; location /assets { try_files $uri =404; } location ~ ^/protected/(.*) { internal; try_files /$site_name_bbjfslw/$1 =404; } location /socket.io { proxy_http_version 1.1; proxy_set_header Upgrade $http_upgrade; proxy_set_header Connection "upgrade"; proxy_set_header X-Frappe-Site-Name $site_name_bbjfslw; proxy_set_header Origin $scheme://$http_host; proxy_set_header Host $host; proxy_pass http://frappe-bench-socketio-server; } location / { rewrite ^(.+)/$ $1 permanent; rewrite ^(.+)/index\.html$ $1 permanent; rewrite ^(.+)\.html$ $1 permanent; location ~ ^/files/.*.(htm|html|svg|xml) { add_header Content-disposition "attachment"; try_files /$site_name_bbjfslw/public/$uri @webserver; } try_files /$site_name_bbjfslw/public/$uri @webserver; } location @webserver { proxy_set_header X-Forwarded-For $remote_addr; proxy_set_header X-Forwarded-Proto $scheme; proxy_set_header X-Frappe-Site-Name $site_name_bbjfslw; proxy_set_header Host $host; proxy_set_header X-Use-X-Accel-Redirect True; proxy_read_timeout 120; proxy_redirect off; proxy_pass http://frappe-bench-frappe; } # error pages error_page 502 /502.html; location /502.html { root /disk/service/web/home/erp/lib/python3.9/site-packages/bench/config/templates; internal; } # optimizations sendfile on; keepalive_timeout 15; client_max_body_size 50m; client_body_buffer_size 16K; client_header_buffer_size 1k; # enable gzip compresion # based on https://mattstauffer.co/blog/enabling-gzip-on-nginx-servers-including-laravel-forge gzip on; gzip_http_version 1.1; gzip_comp_level 5; gzip_min_length 256; gzip_proxied any; gzip_vary on; gzip_types application/atom+xml application/javascript application/json application/rss+xml application/vnd.ms-fontobject application/x-font-ttf application/font-woff application/x-web-app-manifest+json application/xhtml+xml application/xml font/opentype image/svg+xml image/x-icon text/css text/plain text/x-component ; # text/html is always compressed by HttpGzipModule } server { listen 443 ssl; server_name riwollis-box.tcp4.me ; root /disk/service/web/home/erp/frappe-bench/sites; ssl on; ssl_certificate /etc/nginx/ssl/riwollis-box.tcp4.me.crt; ssl_certificate_key /etc/nginx/ssl/riwollis-box.tcp4.me.key; ssl_session_timeout 5m; ssl_session_cache shared:SSL:10m; ssl_session_tickets off; ssl_stapling on; ssl_stapling_verify on; ssl_protocols TLSv1.2 TLSv1.3; ssl_ciphers EECDH+AESGCM:EDH+AESGCM; ssl_ecdh_curve secp384r1; ssl_prefer_server_ciphers on; add_header X-Frame-Options "SAMEORIGIN"; add_header Strict-Transport-Security "max-age=63072000; includeSubDomains; preload"; add_header X-Content-Type-Options nosniff; add_header X-XSS-Protection "1; mode=block"; location /assets { try_files $uri =404; } location ~ ^/protected/(.*) { internal; try_files /$site_name_bbjfslw/$1 =404; } location /socket.io { proxy_http_version 1.1; proxy_set_header Upgrade $http_upgrade; proxy_set_header Connection "upgrade"; proxy_set_header X-Frappe-Site-Name $site_name_bbjfslw; proxy_set_header Origin $scheme://$http_host; proxy_set_header Host $host; proxy_pass http://frappe-bench-socketio-server; } location / { rewrite ^(.+)/$ $1 permanent; rewrite ^(.+)/index\.html$ $1 permanent; rewrite ^(.+)\.html$ $1 permanent; location ~ ^/files/.*.(htm|html|svg|xml) { add_header Content-disposition "attachment"; try_files /$site_name_bbjfslw/public/$uri @webserver; } try_files /$site_name_bbjfslw/public/$uri @webserver; } location @webserver { proxy_set_header X-Forwarded-For $remote_addr; proxy_set_header X-Forwarded-Proto $scheme; proxy_set_header X-Frappe-Site-Name $site_name_bbjfslw; proxy_set_header Host $host; proxy_set_header X-Use-X-Accel-Redirect True; proxy_read_timeout 120; proxy_redirect off; proxy_pass http://frappe-bench-frappe; } # error pages error_page 502 /502.html; location /502.html { root /disk/service/web/home/erp/lib/python3.9/site-packages/bench/config/templates; internal; } # optimizations sendfile on; keepalive_timeout 15; client_max_body_size 50m; client_body_buffer_size 16K; client_header_buffer_size 1k; # enable gzip compresion # based on https://mattstauffer.co/blog/enabling-gzip-on-nginx-servers-including-laravel-forge gzip on; gzip_http_version 1.1; gzip_comp_level 5; gzip_min_length 256; gzip_proxied any; gzip_vary on; gzip_types application/atom+xml application/javascript application/json application/rss+xml application/vnd.ms-fontobject application/x-font-ttf application/font-woff application/x-web-app-manifest+json application/xhtml+xml application/xml font/opentype image/svg+xml image/x-icon text/css text/plain text/x-component ; # text/html is always compressed by HttpGzipModule } # http to https redirect server { listen 80; server_name riwollis-box.tcp4.me ; return 301 https://$host$request_uri; } server { listen 443 ssl; server_name riwollis-shop.tcp4 ; root /disk/service/web/home/erp/frappe-bench/sites; ssl on; ssl_certificate /etc/nginx/ssl/riwollis-shop.tcp4.crt; ssl_certificate_key /etc/nginx/ssl/riwollis-shop.tcp4.key; ssl_session_timeout 5m; ssl_session_cache shared:SSL:10m; ssl_session_tickets off; ssl_stapling on; ssl_stapling_verify on; ssl_protocols TLSv1.2 TLSv1.3; ssl_ciphers EECDH+AESGCM:EDH+AESGCM; ssl_ecdh_curve secp384r1; ssl_prefer_server_ciphers on; add_header X-Frame-Options "SAMEORIGIN"; add_header Strict-Transport-Security "max-age=63072000; includeSubDomains; preload"; add_header X-Content-Type-Options nosniff; add_header X-XSS-Protection "1; mode=block"; location /assets { try_files $uri =404; } location ~ ^/protected/(.*) { internal; try_files /$site_name_bbjfslw/$1 =404; } location /socket.io { proxy_http_version 1.1; proxy_set_header Upgrade $http_upgrade; proxy_set_header Connection "upgrade"; proxy_set_header X-Frappe-Site-Name $site_name_bbjfslw; proxy_set_header Origin $scheme://$http_host; proxy_set_header Host $host; proxy_pass http://frappe-bench-socketio-server; } location / { rewrite ^(.+)/$ $1 permanent; rewrite ^(.+)/index\.html$ $1 permanent; rewrite ^(.+)\.html$ $1 permanent; location ~ ^/files/.*.(htm|html|svg|xml) { add_header Content-disposition "attachment"; try_files /$site_name_bbjfslw/public/$uri @webserver; } try_files /$site_name_bbjfslw/public/$uri @webserver; } location @webserver { proxy_set_header X-Forwarded-For $remote_addr; proxy_set_header X-Forwarded-Proto $scheme; proxy_set_header X-Frappe-Site-Name $site_name_bbjfslw; proxy_set_header Host $host; proxy_set_header X-Use-X-Accel-Redirect True; proxy_read_timeout 120; proxy_redirect off; proxy_pass http://frappe-bench-frappe; } # error pages error_page 502 /502.html; location /502.html { root /disk/service/web/home/erp/lib/python3.9/site-packages/bench/config/templates; internal; } # optimizations sendfile on; keepalive_timeout 15; client_max_body_size 50m; client_body_buffer_size 16K; client_header_buffer_size 1k; # enable gzip compresion # based on https://mattstauffer.co/blog/enabling-gzip-on-nginx-servers-including-laravel-forge gzip on; gzip_http_version 1.1; gzip_comp_level 5; gzip_min_length 256; gzip_proxied any; gzip_vary on; gzip_types application/atom+xml application/javascript application/json application/rss+xml application/vnd.ms-fontobject application/x-font-ttf application/font-woff application/x-web-app-manifest+json application/xhtml+xml application/xml font/opentype image/svg+xml image/x-icon text/css text/plain text/x-component ; # text/html is always compressed by HttpGzipModule } # http to https redirect server { listen 80; server_name riwollis-shop.tcp4 ; return 301 https://$host$request_uri; }