# BASIC SCODOC 9 CONFIG FOR NGINX
# EV, Aug 2021

server {
    # listen on port 80 (http)
    listen 80;
    server_name _;
    location / {
        # redirect any requests to the same URL but on https
        return 301 https://$host$request_uri;
    }
}
server {
    # listen on port 443 (https)
    listen 443 ssl;
    server_name _;
    # location of the self-signed SSL certificate
    ssl_certificate /opt/scodoc-data/certs/cert.pem;
    ssl_certificate_key /opt/scodoc-data/certs/key.pem;
    # write access and error logs to /var/log
    access_log /var/log/nginx/scodoc_access.log;
    error_log /var/log/nginx/scodoc_error.log;
    location / {
        # forward application requests to the gunicorn server
        proxy_pass http://localhost:8000;
        proxy_redirect off;
        proxy_set_header Host $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 https;
        client_max_body_size 16m;
    }
    location /ScoDoc/static {
        # handle static files directly, without forwarding to the application
        alias /opt/scodoc/app/static;
        expires 1d;
    }
    location /ScoDoc/static/bootstrap {
        # (temp.) exception: home page using flask_bootstrap !
        proxy_pass http://localhost:8000;
        proxy_redirect off;
        proxy_set_header Host $host;
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
    }
    location /favicon.ico {
    	alias /opt/scodoc/app/static/icons/favicon.ico;
    }
}