]> code.delx.au - cgiproxy/blobdiff - ruby/proxy.rb
Renamed methods, make output_dir optional
[cgiproxy] / ruby / proxy.rb
old mode 100755 (executable)
new mode 100644 (file)
index 10002f1..9563f88
@@ -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