X-Git-Url: https://code.delx.au/cgiproxy/blobdiff_plain/b76ed1c2c7ba8016a805e6be96cfd2f471e1527e..40070216e54515585ee0a6b6ab6675cee49083d2:/ruby/proxy.rb diff --git a/ruby/proxy.rb b/ruby/proxy.rb old mode 100755 new mode 100644 index 10002f1..9563f88 --- a/ruby/proxy.rb +++ b/ruby/proxy.rb @@ -11,7 +11,7 @@ class NilClass end -def getParams(url) +def get_params(url) if !ENV["PATH_INFO"].empty? url += ENV["PATH_INFO"] end @@ -23,15 +23,16 @@ def getParams(url) use_ssl = url.scheme == 'https' + filename = url.path.split("/")[-1] path = url.path if !ENV["QUERY_STRING"].empty? path += "?" + ENV["QUERY_STRING"] end - return url.host, url.port, use_ssl, path + return url.host, url.port, use_ssl, filename, path end -def createRequest(method, path) +def create_request(method, path, ff_header) if method == "GET" req = Net::HTTP::Get.new(path) elsif method == "POST" @@ -40,11 +41,8 @@ def createRequest(method, path) else raise RuntimeError, "No support for method: #{method}" end - return req -end -def insertHeaders(req, ffHeader) - if ffHeader + if ff_header req["X-Forwarded-For"] = ENV["REMOTE_ADDR"] end req["Host"] = ENV["HTTP_HOST"] @@ -59,33 +57,42 @@ def insertHeaders(req, ffHeader) req["Accept-Charset"] = ENV["HTTP_ACCEPT_CHARSET"] req["Accept-Encoding"] = ENV["HTTP_ACCEPT_ENCODING"] req["Accept-Language"] = ENV["HTTP_ACCEPT_LANGUAGE"] + + return req end -def doRequest(req, host, port, use_ssl) +def do_proxy(req, host, port, use_ssl, filename, output_dir) # Make the request http = Net::HTTP.new(host, port) http.use_ssl = use_ssl - res = http.request(req) + res = http.request req do |res| - # Tweak the headers a little - res.delete("transfer-encoding") - res.delete("transfer-length") - res["connection"] = "close" + # Tweak the headers a little + res.delete("transfer-encoding") + res.delete("transfer-length") + res["connection"] = "close" - return res -end + if res.code != "200" + res["Status"] = "#{res.code} #{res.message}" + end + res.each_capitalized_name do |key| + res.get_fields(key).each do |value| + print "#{key}: #{value}\r\n" + end + end + print "\r\n" -def printResult(res) - if res.code != "200" - res["Status"] = "#{res.code} #{res.message}" - end - res.each_capitalized_name do |key| - res.get_fields(key).each do |value| - print "#{key}: #{value}\r\n" + out = nil + if output_dir + out = File.open("#{output_dir}/#{filename}", 'w') + end + res.read_body do |chunk| + print chunk + if out + out.write chunk + end end end - print "\r\n" - print res.body end def debug(msg) @@ -94,11 +101,9 @@ def debug(msg) } end -def proxyTo(basePath, ffHeader=True) - host, port, use_ssl, path = getParams(basePath) - req = createRequest(ENV["REQUEST_METHOD"], path) - insertHeaders(req, ffHeader) - res = doRequest(req, host, port, use_ssl) - printResult(res) +def proxy_to(base_path, ff_header=True, output_dir=nil) + host, port, use_ssl, filename, path = get_params(base_path) + req = create_request(ENV["REQUEST_METHOD"], path, ff_header) + do_proxy(req, host, port, use_ssl, filename, output_dir) end