myexperiment-hackers
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

[myexperiment-hackers] [2764] branches/rails2/config/initializers/mongre


From: noreply
Subject: [myexperiment-hackers] [2764] branches/rails2/config/initializers/mongrel.rb: added workaround for mongrel and rails 2 issue
Date: Tue, 25 Oct 2011 14:05:25 -0400 (EDT)

Revision
2764
Author
dgc
Date
2011-10-25 14:05:24 -0400 (Tue, 25 Oct 2011)

Log Message

added workaround for mongrel and rails 2 issue

Added Paths

Diff

Added: branches/rails2/config/initializers/mongrel.rb (0 => 2764)


--- branches/rails2/config/initializers/mongrel.rb	                        (rev 0)
+++ branches/rails2/config/initializers/mongrel.rb	2011-10-25 18:05:24 UTC (rev 2764)
@@ -0,0 +1,84 @@
+# from https://gist.github.com/826692
+
+if ['2.3.8', '2.3.9', '2.3.10', '2.3.11'].include?(Rails.version) && Gem.available?('mongrel', '~>1.1.5') && self.class.const_defined?(:Mongrel)
+  
+  # Pulled right from latest rack. Old looked like this in 1.1.0 version.
+  # 
+  # def [](k)
+  #   super(@names[k] ||= @names[k.downcase])
+  # end
+  # 
+  module Rack
+    module Utils
+      class HeaderHash < Hash
+        def [](k)
+          super(@names[k]) if @names[k]
+          super(@names[k.downcase])
+        end
+      end
+    end
+  end
+  
+  # Code pulled from the ticket above.
+  # 
+  class Mongrel::CGIWrapper
+    def header_with_rails_fix(options = 'text/html')
+      @head['cookie'] = options.delete('cookie').flatten.map { |v| v.sub(/^\n/,'') } if options.class != String and options['cookie']
+      header_without_rails_fix(options)
+    end
+    alias_method_chain :header, :rails_fix
+  end
+  
+  # Pulled right from 2.3.8 ActionPack. Simple diff was
+  # 
+  # if headers.include?('Set-Cookie')
+  #   headers['cookie'] = headers.delete('Set-Cookie').split("\n")
+  # end
+  # 
+  # to 
+  # 
+  # if headers['Set-Cookie']
+  #   headers['cookie'] = headers.delete('Set-Cookie').split("\n")
+  # end
+  #       
+  module ActionController
+    class CGIHandler
+      def self.dispatch_cgi(app, cgi, out = $stdout)
+        env = cgi.__send__(:env_table)
+        env.delete "HTTP_CONTENT_LENGTH"
+        cgi.stdinput.extend ProperStream
+        env["SCRIPT_NAME"] = "" if env["SCRIPT_NAME"] == "/"
+        env.update({
+          "rack.version" => [0,1],
+          "rack.input" => cgi.stdinput,
+          "rack.errors" => $stderr,
+          "rack.multithread" => false,
+          "rack.multiprocess" => true,
+          "rack.run_once" => false,
+          "rack.url_scheme" => ["yes", "on", "1"].include?(env["HTTPS"]) ? "https" : "http"
+        })
+        env["QUERY_STRING"] ||= ""
+        env["HTTP_VERSION"] ||= env["SERVER_PROTOCOL"]
+        env["REQUEST_PATH"] ||= "/"
+        env.delete "PATH_INFO" if env["PATH_INFO"] == ""
+        status, headers, body = app.call(env)
+        begin
+          out.binmode if out.respond_to?(:binmode)
+          out.sync = false if out.respond_to?(:sync=)
+          headers['Status'] = status.to_s
+          if headers['Set-Cookie']
+            headers['cookie'] = headers.delete('Set-Cookie').split("\n")
+          end
+          out.write(cgi.header(headers))
+          body.each { |part|
+            out.write part
+            out.flush if out.respond_to?(:flush)
+          }
+        ensure
+          body.close if body.respond_to?(:close)
+        end
+      end
+    end
+  end
+  
+end

reply via email to

[Prev in Thread] Current Thread [Next in Thread]