X-Git-Url: https://code.delx.au/cgiproxy/blobdiff_plain/9a1c573100b944eec9b5e55d95360d11182d5376..b76ed1c2c7ba8016a805e6be96cfd2f471e1527e:/ruby/proxy.rb diff --git a/ruby/proxy.rb b/ruby/proxy.rb index 6f98be7..10002f1 100755 --- a/ruby/proxy.rb +++ b/ruby/proxy.rb @@ -1,6 +1,7 @@ #!/usr/bin/env ruby require 'net/http' +require 'net/https' require 'uri' class NilClass @@ -16,16 +17,18 @@ def getParams(url) end url = URI.parse(url); - if url.scheme != "http" + if !["http", "https"].include? url.scheme raise RuntimeError, "Unsupported scheme: #{url.scheme}" end + use_ssl = url.scheme == 'https' + path = url.path if !ENV["QUERY_STRING"].empty? path += "?" + ENV["QUERY_STRING"] end - return url.host, url.port, path + return url.host, url.port, use_ssl, path end def createRequest(method, path) @@ -40,8 +43,10 @@ def createRequest(method, path) return req end -def insertHeaders(req) - req["X-Forwarded-For"] = ENV["REMOTE_ADDR"] +def insertHeaders(req, ffHeader) + if ffHeader + req["X-Forwarded-For"] = ENV["REMOTE_ADDR"] + end req["Host"] = ENV["HTTP_HOST"] req["Cookie"] = ENV["HTTP_COOKIE"] req["Referer"] = ENV["HTTP_REFERER"] @@ -56,11 +61,11 @@ def insertHeaders(req) req["Accept-Language"] = ENV["HTTP_ACCEPT_LANGUAGE"] end -def doRequest(req, host, port) +def doRequest(req, host, port, use_ssl) # Make the request - res = Net::HTTP.start(host, port) do |http| - http.request(req) - end + http = Net::HTTP.new(host, port) + http.use_ssl = use_ssl + res = http.request(req) # Tweak the headers a little res.delete("transfer-encoding") @@ -74,13 +79,8 @@ def printResult(res) if res.code != "200" res["Status"] = "#{res.code} #{res.message}" end - res.each_capitalized do |key, value| - if key == "Set-Cookie" - values = value.split(",") - else - values = [value] - end - values.each do |value| + res.each_capitalized_name do |key| + res.get_fields(key).each do |value| print "#{key}: #{value}\r\n" end end @@ -94,11 +94,11 @@ def debug(msg) } end -def proxyTo(basePath) - host, port, path = getParams(basePath) +def proxyTo(basePath, ffHeader=True) + host, port, use_ssl, path = getParams(basePath) req = createRequest(ENV["REQUEST_METHOD"], path) - insertHeaders(req) - res = doRequest(req, host, port) + insertHeaders(req, ffHeader) + res = doRequest(req, host, port, use_ssl) printResult(res) end