static.nginx.d.conf.j2 1.7 KB
Newer Older
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
server {
    listen       80;
    listen       [::]:80;
    server_name  {{ static_conference_domain }};

    access_log   /var/log/nginx/{{ static_conference_domain }}/access.log reduced;
    error_log    /var/log/nginx/{{ static_conference_domain }}/error.log;

    include snippets/letsencrypt.conf;

    location / {
        access_log off;
        return 301 https://$server_name$request_uri;
    }
}

server {
    listen       443 ssl http2;
    listen       [::]:443 ssl http2;
    server_name  {{ static_conference_domain }};

    access_log   /var/log/nginx/{{ static_conference_domain }}/access.log reduced;
    error_log    /var/log/nginx/{{ static_conference_domain }}/error.log;

    ssl_certificate      /etc/letsencrypt/live/{{ static_conference_domain }}/fullchain.pem;
    ssl_certificate_key  /etc/letsencrypt/live/{{ static_conference_domain }}/privkey.pem;
    ssl_trusted_certificate /etc/letsencrypt/live/{{ static_conference_domain }}/chain.pem;

    # Security headers
    add_header X-Frame-Options "SAMEORIGIN" always;
    add_header X-Xss-Protection "1; mode=block" always;
    add_header Referrer-Policy "same-origin";
    add_header Feature-Policy "geolocation 'none' ;midi 'none'; sync-xhr 'none'; microphone 'none'; camera 'none'; magnetometer 'none'; gyroscope 'none'; speaker 'none'; fullscreen 'none'; payment 'none';";
    add_header Content-Security-Policy "default-src 'self';";
    add_header X-Content-Type-Options "nosniff" always;

    # Apply HSTS header again, since adding a header removes previous headers
    add_header Strict-Transport-Security $hsts_header;

    autoindex on;

    location /2019 {
        return 301 $scheme://$server_name;
    }

    root {{ static_conference_dir }}/;
}