I have a reverse proxy on nginx which proxies quite a few sites. I have recently enabled HTTP Strict Transport Security for all SSL-enabled websites. I now have one site that doesn't want to have this enabled.
I thought I would just do a simple check if my upstream already sent me a Strict-Transport-Security
-header, and if not, just add one. That way, my upstream could send an STS header containing max-age=0
to avoid having HSTS enabled by the proxy.
I thought I'd just change my configuration as follows:
location / { proxy_pass http://webservers; proxy_redirect off; proxy_set_header Host $host; proxy_set_header X-Forwarded-For $remote_addr; proxy_set_header X-Forwarded-Proto "https"; if ($upstream_http_strict_transport_security = "") { add_header Strict-Transport-Security "max-age=15552000"; } }
But, probably because if is evil, this doesn't work. I have tried a bunch of different things to make sure the variable actually exists (which is the case), but nothing seems to help.
How could I make this work?