191 lines
4.9 KiB
Nginx Configuration File
191 lines
4.9 KiB
Nginx Configuration File
user www-data;
|
|
worker_processes auto;
|
|
pid /run/nginx.pid;
|
|
|
|
events {
|
|
worker_connections 768;
|
|
}
|
|
|
|
http {
|
|
include mime.types;
|
|
default_type application/octet-stream;
|
|
|
|
charset utf-8;
|
|
|
|
sendfile on;
|
|
tcp_nopush on;
|
|
tcp_nodelay on;
|
|
keepalive_timeout 65;
|
|
types_hash_max_size 2048;
|
|
server_tokens off;
|
|
|
|
ssl_protocols TLSv1.2 TLSv1.3;
|
|
ssl_prefer_server_ciphers on;
|
|
|
|
ssl_certificate /etc/letsencrypt/live/grapheneos.org/fullchain.pem;
|
|
ssl_certificate_key /etc/letsencrypt/live/grapheneos.org/privkey.pem;
|
|
ssl_dhparam /etc/nginx/ssl-dhparams.pem;
|
|
ssl_session_cache shared:SSL:10m;
|
|
ssl_session_timeout 1d;
|
|
ssl_session_tickets off;
|
|
ssl_ciphers ECDHE-ECDSA-AES128-GCM-SHA256:ECDHE-RSA-AES128-GCM-SHA256:ECDHE-ECDSA-AES256-GCM-SHA384:ECDHE-RSA-AES256-GCM-SHA384:ECDHE-ECDSA-CHACHA20-POLY1305:ECDHE-RSA-CHACHA20-POLY1305:DHE-RSA-AES128-GCM-SHA256:DHE-RSA-AES256-GCM-SHA384;
|
|
|
|
ssl_trusted_certificate /etc/letsencrypt/live/grapheneos.org/chain.pem;
|
|
ssl_stapling on;
|
|
ssl_stapling_verify on;
|
|
# maintained by certbot-ocsp-fetcher
|
|
ssl_stapling_file /etc/nginx/ocsp-cache/grapheneos.org.der;
|
|
|
|
access_log /var/log/nginx/access.log;
|
|
error_log /var/log/nginx/error.log;
|
|
|
|
gzip_vary on;
|
|
|
|
server {
|
|
listen 80;
|
|
listen [::]:80;
|
|
server_name www.grapheneos.org grapheneos.org;
|
|
|
|
root /var/empty;
|
|
|
|
return 301 https://grapheneos.org$request_uri;
|
|
}
|
|
|
|
server {
|
|
listen 443 ssl http2;
|
|
listen [::]:443 ssl http2;
|
|
server_name www.grapheneos.org;
|
|
|
|
root /var/empty;
|
|
|
|
include /etc/nginx/snippets/security-headers.conf;
|
|
|
|
return 301 https://grapheneos.org$request_uri;
|
|
}
|
|
|
|
server {
|
|
listen 443 ssl http2;
|
|
listen [::]:443 ssl http2;
|
|
server_name grapheneos.org;
|
|
|
|
root /var/www/html;
|
|
error_page 403 =404 /404.html;
|
|
error_page 404 /404.html;
|
|
|
|
include /etc/nginx/snippets/security-headers.conf;
|
|
gzip_static on;
|
|
|
|
if ($request_uri ~ ^/(.*)\.html$) {
|
|
return 301 /$1;
|
|
}
|
|
|
|
location = /security.txt {
|
|
return 301 /.well-known/security.txt;
|
|
}
|
|
|
|
location = /graphene.png {
|
|
return 301 /logo.png;
|
|
}
|
|
|
|
location = /pdfviewer_privacy_policy {
|
|
return 301 /pdfviewer-privacy-policy;
|
|
}
|
|
|
|
location = /safari_pinned_tab_icon.svg {
|
|
return 301 /mask-icon.svg;
|
|
}
|
|
|
|
location = /safari-pinned-tab-icon.svg {
|
|
return 301 /mask-icon.svg;
|
|
}
|
|
|
|
location = /bitcoin_address.png {
|
|
return 301 /bitcoin-donation.png;
|
|
}
|
|
|
|
location = /bitcoin-address.png {
|
|
return 301 /bitcoin-donation.png;
|
|
}
|
|
|
|
# mangled backlinks to /install
|
|
location = /installMinimal {
|
|
return 301 /install;
|
|
}
|
|
|
|
location = /LICENSE {
|
|
default_type text/plain;
|
|
}
|
|
|
|
location = /404 {
|
|
internal;
|
|
http2_push /grapheneos.css?20;
|
|
}
|
|
|
|
location = /404.html {
|
|
internal;
|
|
http2_push /grapheneos.css?20;
|
|
}
|
|
|
|
location ~ "^(.*)/index$" {
|
|
return 301 $1/;
|
|
}
|
|
|
|
location ~ "\.(ico|webmanifest)$" {
|
|
include /etc/nginx/snippets/security-headers.conf;
|
|
add_header Cache-Control "public, max-age=604800";
|
|
}
|
|
|
|
location ~ "\.(css|js|svg)$" {
|
|
include /etc/nginx/snippets/security-headers.conf;
|
|
add_header Cache-Control "public, max-age=31536000";
|
|
}
|
|
|
|
location ~ "\.(png|woff2)$" {
|
|
include /etc/nginx/snippets/security-headers.conf;
|
|
add_header Cache-Control "public, max-age=31536000";
|
|
gzip_static off;
|
|
}
|
|
|
|
location ~ "\.(json|pdf|txt|xml)$" {
|
|
include /etc/nginx/snippets/security-headers.conf;
|
|
add_header Cache-Control "public, max-age=1800";
|
|
}
|
|
|
|
# https://www.twipu.com/GrapheneOS doesn't handle links with fragments properly
|
|
location ~ "^/(.*)<a href=$" {
|
|
return 301 https://grapheneos.org/$1;
|
|
}
|
|
|
|
location ~ "\.(br|gz)" {
|
|
internal;
|
|
}
|
|
|
|
location / {
|
|
include /etc/nginx/snippets/security-headers.conf;
|
|
add_header Cache-Control "public, max-age=1800";
|
|
try_files $uri $uri.html $uri/ =404;
|
|
http2_push /grapheneos.css?20;
|
|
}
|
|
}
|
|
|
|
server {
|
|
listen 80;
|
|
listen [::]:80;
|
|
server_name mta-sts.grapheneos.org mta-sts.mail.grapheneos.org;
|
|
|
|
root /var/empty;
|
|
|
|
return 301 https://$host$request_uri;
|
|
}
|
|
|
|
server {
|
|
listen 443 ssl http2;
|
|
listen [::]:443 ssl http2;
|
|
server_name mta-sts.grapheneos.org mta-sts.mail.grapheneos.org;
|
|
|
|
root /var/www/mta-sts;
|
|
|
|
include /etc/nginx/snippets/security-headers.conf;
|
|
}
|
|
}
|