diff options
-rw-r--r-- | lib/yahns/http_client.rb | 11 | ||||
-rw-r--r-- | test/test_ssl.rb | 5 |
2 files changed, 13 insertions, 3 deletions
diff --git a/lib/yahns/http_client.rb b/lib/yahns/http_client.rb index c300742..272db85 100644 --- a/lib/yahns/http_client.rb +++ b/lib/yahns/http_client.rb @@ -206,8 +206,17 @@ class Yahns::HttpClient < Kgio::Socket # :nodoc: end end + env.merge!(k.app_defaults) + + # workaround stupid unicorn_http parser behavior when it parses HTTP_HOST + if env['HTTPS'] == 'on'.freeze && + env['HTTP_HOST'] && + env['SERVER_PORT'] == '80'.freeze + env['SERVER_PORT'] = '443'.freeze + end + # run the rack app - status, headers, body = k.app.call(env.merge!(k.app_defaults)) + status, headers, body = k.app.call(env) return :ignore if app_hijacked?(env, body) if status.to_i == 100 rv = http_100_response(env) and return rv diff --git a/test/test_ssl.rb b/test/test_ssl.rb index fe7e09e..5fc2b52 100644 --- a/test/test_ssl.rb +++ b/test/test_ssl.rb @@ -71,7 +71,7 @@ AQjjxMXhwULlmuR/K+WwlaZPiLIBYalLAZQ7ZbOPeVkJ8ePao0eLAgEC cfg.instance_eval do ru = lambda do |env| case path_info = env['PATH_INFO'] - when '/rack.url_scheme', '/HTTPS' + when '/rack.url_scheme', '/HTTPS', '/SERVER_PORT' s = env[path_info[1..-1]] # remove leading slash s = s.inspect if s.nil? [ 200, { @@ -100,7 +100,8 @@ AQjjxMXhwULlmuR/K+WwlaZPiLIBYalLAZQ7ZbOPeVkJ8ePao0eLAgEC buf = ''.dup { '/' => 'HI', '/rack.url_scheme' => 'https', - '/HTTPS' => 'on' + '/HTTPS' => 'on', + '/SERVER_PORT' => '443', }.each do |path, exp| client.write("GET #{path} HTTP/1.1\r\nHost: example.com\r\n\r\n") buf.clear |