diff options
Diffstat (limited to 'actionpack/lib')
| -rw-r--r-- | actionpack/lib/action_dispatch/http/mime_negotiation.rb | 8 | ||||
| -rwxr-xr-x | actionpack/lib/action_dispatch/http/request.rb | 6 | ||||
| -rw-r--r-- | actionpack/lib/action_dispatch/middleware/params_parser.rb | 6 | 
3 files changed, 13 insertions, 7 deletions
| diff --git a/actionpack/lib/action_dispatch/http/mime_negotiation.rb b/actionpack/lib/action_dispatch/http/mime_negotiation.rb index fec250e928..be89924015 100644 --- a/actionpack/lib/action_dispatch/http/mime_negotiation.rb +++ b/actionpack/lib/action_dispatch/http/mime_negotiation.rb @@ -5,7 +5,7 @@ module ActionDispatch        #        # For backward compatibility, the post \format is extracted from the        # X-Post-Data-Format HTTP header if present. -      def content_type +      def content_mime_type          @env["action_dispatch.request.content_type"] ||= begin            if @env['CONTENT_TYPE'] =~ /^([^,\;]*)/              Mime::Type.lookup($1.strip.downcase) @@ -15,13 +15,17 @@ module ActionDispatch          end        end +      def content_type +        content_mime_type && content_mime_type.to_s +      end +        # Returns the accepted MIME type for the request.        def accepts          @env["action_dispatch.request.accepts"] ||= begin            header = @env['HTTP_ACCEPT'].to_s.strip            if header.empty? -            [content_type] +            [content_mime_type]            else              Mime::Type.parse(header)            end diff --git a/actionpack/lib/action_dispatch/http/request.rb b/actionpack/lib/action_dispatch/http/request.rb index ea9f0f99c2..8b8426b5aa 100755 --- a/actionpack/lib/action_dispatch/http/request.rb +++ b/actionpack/lib/action_dispatch/http/request.rb @@ -96,11 +96,11 @@ module ActionDispatch      end      def forgery_whitelisted? -      method == :get || xhr? || content_type.nil? || !content_type.verify_request? +      method == :get || xhr? || content_mime_type.nil? || !content_mime_type.verify_request?      end      def media_type -      content_type.to_s +      content_mime_type.to_s      end      # Returns the content length of the request as an integer. @@ -157,7 +157,7 @@ module ActionDispatch      end      def form_data? -      FORM_DATA_MEDIA_TYPES.include?(content_type.to_s) +      FORM_DATA_MEDIA_TYPES.include?(content_mime_type.to_s)      end      def body_stream #:nodoc: diff --git a/actionpack/lib/action_dispatch/middleware/params_parser.rb b/actionpack/lib/action_dispatch/middleware/params_parser.rb index f4c4324fb0..18a3688bb0 100644 --- a/actionpack/lib/action_dispatch/middleware/params_parser.rb +++ b/actionpack/lib/action_dispatch/middleware/params_parser.rb @@ -25,7 +25,9 @@ module ActionDispatch          return false if request.content_length.zero? -        mime_type = content_type_from_legacy_post_data_format_header(env) || request.content_type +        mime_type = content_type_from_legacy_post_data_format_header(env) || +          request.content_mime_type +          strategy = @parsers[mime_type]          return false unless strategy @@ -53,7 +55,7 @@ module ActionDispatch          raise            { "body"           => request.raw_post, -            "content_type"   => request.content_type, +            "content_type"   => request.content_mime_type,              "content_length" => request.content_length,              "exception"      => "#{e.message} (#{e.class})",              "backtrace"      => e.backtrace } | 
