user  nginx;
worker_processes  1;

error_log  /var/log/nginx/error.log warn;
pid        /var/run/nginx.pid;


events {
	worker_connections  1024;
}


http {
	include       /etc/nginx/mime.types;
	default_type  application/octet-stream;

	types {
		application/manifest+json webmanifest;
	}

	log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
					  '$status $body_bytes_sent "$http_referer" '
					  '"$http_user_agent" "$http_x_forwarded_for"';

	access_log  /var/log/nginx/access.log  main;

	sendfile        on;
	#tcp_nopush     on;

	keepalive_timeout  65;

	gzip  on;

	gzip_vary on;
	gzip_proxied any;
	gzip_comp_level 6;
	gzip_buffers 16 8k;
	gzip_http_version 1.1;
	gzip_min_length 256;
	gzip_types
		text/plain
		text/css
		application/json
		application/x-javascript
		application/javascript
		text/xml
		application/xml
		application/xml+rss
		text/javascript
		application/vnd.ms-fontobject
		application/x-font-ttf
		font/opentype
		image/svg+xml
		image/x-icon
		audio/wav;

	map_hash_max_size 128;
	map_hash_bucket_size 128;

	# Expires map
	map $sent_http_content_type $expires {
		default                       off;
		text/css                      max;
		application/javascript        max;
		text/javascript               max;
		application/vnd.ms-fontobject max;
		application/x-font-ttf        max;
		font/opentype                 max;
		font/woff2                    max;
		image/svg+xml                 max;
		image/x-icon                  max;
		audio/wav                     max;
		~images/                      max;
		~font/                        max;
	}

	server {
		listen 80;
		listen 81  default_server http2 proxy_protocol; ## Needed when behind HAProxy with SSL termination + HTTP/2 support

		server_name  _;

		expires $expires;

		root   /usr/share/nginx/html;

		# all assets contain hash in filename, cache forever
		location ^~ /assets/ {
			add_header Cache-Control "public, max-age=31536000, s-maxage=31536000, immutable";
			try_files $uri =404;
		}

		# all workbox scripts are compiled with hash in filename, cache forever3
		location ^~ /workbox- {
			add_header Cache-Control "public, max-age=31536000, s-maxage=31536000, immutable";
			try_files $uri =404;
		}

		# assume that everything else is handled by the application router, by injecting the index.html.
		location / {
			autoindex off;
			expires off;
			add_header Cache-Control "public, max-age=0, s-maxage=0, must-revalidate" always;
			try_files $uri /index.html =404;
		}

		location ~* .(txt|webmanifest|css|js|mjs|map|svg|jpg|jpeg|png|ico|ttf|woff|woff2|wav)$ {
			try_files $uri $uri/ =404;
		}

		error_page   500 502 503 504  /50x.html;
		location = /50x.html {
		}
	}
}