aboutsummaryrefslogtreecommitdiffstats
path: root/actionpack/lib/action_controller/cgi/ext/query_extension.rb
diff options
context:
space:
mode:
authorYehuda Katz <wycats@gmail.com>2009-01-30 11:30:27 -0800
committerYehuda Katz <wycats@gmail.com>2009-01-30 11:30:27 -0800
commit3030bc90c95e335d726f06fd7a61ed96055e9109 (patch)
tree5b079250b368f0e8af6d2f72a4278fdab3382b26 /actionpack/lib/action_controller/cgi/ext/query_extension.rb
parentae42163bf5497849e4fcbb736505910c17640459 (diff)
parent85750f22c90c914a429116fb908990c5a2c68379 (diff)
downloadrails-3030bc90c95e335d726f06fd7a61ed96055e9109.tar.gz
rails-3030bc90c95e335d726f06fd7a61ed96055e9109.tar.bz2
rails-3030bc90c95e335d726f06fd7a61ed96055e9109.zip
Merge commit 'rails/3-0-unstable'
Conflicts: actionpack/lib/action_controller/base.rb actionpack/lib/action_dispatch/http/mime_type.rb actionpack/lib/action_dispatch/http/request.rb actionpack/lib/action_view/base.rb actionpack/lib/action_view/paths.rb actionpack/test/controller/session/cookie_store_test.rb actionpack/test/dispatch/rack_test.rb actionpack/test/dispatch/request_test.rb
Diffstat (limited to 'actionpack/lib/action_controller/cgi/ext/query_extension.rb')
-rw-r--r--actionpack/lib/action_controller/cgi/ext/query_extension.rb22
1 files changed, 22 insertions, 0 deletions
diff --git a/actionpack/lib/action_controller/cgi/ext/query_extension.rb b/actionpack/lib/action_controller/cgi/ext/query_extension.rb
new file mode 100644
index 0000000000..9620fd2873
--- /dev/null
+++ b/actionpack/lib/action_controller/cgi/ext/query_extension.rb
@@ -0,0 +1,22 @@
+require 'cgi'
+
+class CGI #:nodoc:
+ module QueryExtension
+ # Remove the old initialize_query method before redefining it.
+ remove_method :initialize_query
+
+ # Neuter CGI parameter parsing.
+ def initialize_query
+ # Fix some strange request environments.
+ env_table['REQUEST_METHOD'] ||= 'GET'
+
+ # POST assumes missing Content-Type is application/x-www-form-urlencoded.
+ if env_table['CONTENT_TYPE'].blank? && env_table['REQUEST_METHOD'] == 'POST'
+ env_table['CONTENT_TYPE'] = 'application/x-www-form-urlencoded'
+ end
+
+ @cookies = CGI::Cookie::parse(env_table['HTTP_COOKIE'] || env_table['COOKIE'])
+ @params = {}
+ end
+ end
+end