]> code.delx.au - cgiproxy/blobdiff - ruby/proxy.rb
Made the x-forwarded-for header optional
[cgiproxy] / ruby / proxy.rb
index 6f98be7af10d85084d0541698a46100483f4081b..11b14d2bfa3489be0a300e5ca98d5c1bb7b272dc 100755 (executable)
@@ -40,8 +40,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"]
@@ -74,13 +76,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,10 +91,10 @@ def debug(msg)
        }
 end
 
-def proxyTo(basePath)
+def proxyTo(basePath, ffHeader=True)
        host, port, path = getParams(basePath)
        req = createRequest(ENV["REQUEST_METHOD"], path)
-       insertHeaders(req)
+       insertHeaders(req, ffHeader)
        res = doRequest(req, host, port)
        printResult(res)
 end