# Default MNOE nginx configuration for the web-ruby docker image used by Nex!™: # github.com/maestrano/docker-web-ruby server {
listen 80 default_server; server_name _; root /app/public; try_files $uri/index.html $uri @app; #----------------------------------------------------------- # Mnoe custom caching configuration #----------------------------------------------------------- # Empty location block to force the html block to trigger location ~* ^/(admin|dashboard)/$ { } # Revalidate html pages on each request and fetch the latest version if the content change location ~* \.(html?|json)$ { add_header Cache-Control "max-age=0, must-revalidate"; } # Same for config.js location ~* config\.js$ { add_header Cache-Control "max-age=0, must-revalidate"; } # CSS and Javascript # "far future expires" of 1 year as the assets are fingerprinted location ~* \.(?:css|js)$ { add_header Cache-Control "max-age=31536000"; # access_log off; } #----------------------------------------------------------- # Proxy to Puma #----------------------------------------------------------- location @app { # # Wide-open CORS config # if ($request_method = 'OPTIONS') { # add_header 'Access-Control-Allow-Origin' '*'; # add_header 'Access-Control-Allow-Methods' 'GET, POST, OPTIONS'; # add_header 'Access-Control-Allow-Headers' 'Keep-Alive,User-Agent,X-Requested-With,If-Modified-Since,Cache-Control,Content-Type,x-csrf-token,Authorization'; # add_header 'Access-Control-Max-Age' 1728000; # add_header 'Content-Type' 'text/plain charset=UTF-8'; # add_header 'Content-Length' 0; # return 204; # } # if ($request_method = 'POST') { # add_header 'Access-Control-Allow-Origin' '*'; # add_header 'Access-Control-Allow-Methods' 'GET, POST, OPTIONS'; # add_header 'Access-Control-Allow-Headers' 'Keep-Alive,User-Agent,X-Requested-With,If-Modified-Since,Cache-Control,Content-Type,x-csrf-token,Authorization'; # } # if ($request_method = 'GET') { # add_header 'Access-Control-Allow-Origin' '*'; # add_header 'Access-Control-Allow-Methods' 'GET, POST, OPTIONS'; # add_header 'Access-Control-Allow-Headers' 'Keep-Alive,User-Agent,X-Requested-With,If-Modified-Since,Cache-Control,Content-Type,Authorization'; # } proxy_pass http://127.0.0.1:3000; proxy_redirect off; proxy_connect_timeout 600; proxy_send_timeout 600; proxy_read_timeout 600; send_timeout 600; } error_page 500 502 503 504 /500.html; client_max_body_size 4G; keepalive_timeout 10;
}