From 3fa42851bf44d11ae7a7b89acf0ea8c470a2b60c Mon Sep 17 00:00:00 2001 From: Systho Date: Mon, 16 Apr 2018 10:08:24 +0200 Subject: [PATCH] Use correct protocol (#1425) Currently we can run webpacker in either http or https mode. But if we run webpacker in http mode but access it through a reverse proxy handling https, then it will break because the reverse proxy will have set HTTP_X_FORWARDED_PROTO to https and webpack-dev-server will try to understand the request as a secured one. We must override X_FORWARDED_PROTO in the same way as we override the other headers. --- lib/webpacker/dev_server_proxy.rb | 1 + 1 file changed, 1 insertion(+) diff --git a/lib/webpacker/dev_server_proxy.rb b/lib/webpacker/dev_server_proxy.rb index 04c3c1eee..67f548287 100644 --- a/lib/webpacker/dev_server_proxy.rb +++ b/lib/webpacker/dev_server_proxy.rb @@ -11,6 +11,7 @@ def rewrite_response(response) def perform_request(env) if env["PATH_INFO"].start_with?("/#{public_output_uri_path}") && Webpacker.dev_server.running? env["HTTP_HOST"] = env["HTTP_X_FORWARDED_HOST"] = env["HTTP_X_FORWARDED_SERVER"] = Webpacker.dev_server.host_with_port + env["HTTP_X_FORWARDED_PROTO"] = Webpacker.dev_server.protocol env["SCRIPT_NAME"] = "" super(env)