upstream puma { server unix:/<%= fetch(:deploy_to) %>/shared/tmp/sockets/puma.sock fail_timeout=0; } server { listen 80 default deferred; root <%= fetch(:deploy_to) %>/current/public; location ^~ /assets/ { gzip_static on; expires max; add_header Cache-Control public; } try_files $uri/index.html $uri @puma; location @puma { proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_set_header Host $http_host; proxy_redirect off; proxy_pass http://puma; } error_page 500 502 503 504 /500.html; client_max_body_size 4G; keepalive_timeout 10; } <% if fetch(:enable_ssl) %> server { listen 443 default deferred; root <%= fetch(:deploy_to) %>/current/public; location ^~ /assets/ { gzip_static on; expires max; add_header Cache-Control public; } try_files $uri/index.html $uri @puma; location @puma { proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_set_header X-Forwarded-Proto https; proxy_set_header Host $http_host; proxy_redirect off; proxy_pass http://puma; } error_page 500 502 503 504 /500.html; client_max_body_size 4G; keepalive_timeout 10; ssl on; ssl_certificate <%= fetch(:deploy_to) %>/shared/ssl_cert.crt; ssl_certificate_key <%= fetch(:deploy_to) %>/shared/ssl_private_key.key; }# <% end %>