diff options
Diffstat (limited to 'actionpack/lib/action_controller')
4 files changed, 34 insertions, 19 deletions
| diff --git a/actionpack/lib/action_controller/metal/helpers.rb b/actionpack/lib/action_controller/metal/helpers.rb index d2cbbd3330..35facd13c8 100644 --- a/actionpack/lib/action_controller/metal/helpers.rb +++ b/actionpack/lib/action_controller/metal/helpers.rb @@ -1,4 +1,3 @@ -  module ActionController    # The \Rails framework provides a large number of helpers for working with assets, dates, forms,    # numbers and model objects, to name a few. These helpers are available to all templates @@ -91,11 +90,11 @@ module ActionController        end        def all_helpers_from_path(path) -        helpers = [] -        Array(path).each do |_path| -          extract  = /^#{Regexp.quote(_path.to_s)}\/?(.*)_helper.rb$/ +        helpers = Array(path).flat_map do |_path| +          extract = /^#{Regexp.quote(_path.to_s)}\/?(.*)_helper.rb$/            names = Dir["#{_path}/**/*_helper.rb"].map { |file| file.sub(extract, '\1') } -          helpers += names.sort +          names.sort! +          names          end          helpers.uniq!          helpers diff --git a/actionpack/lib/action_controller/metal/http_authentication.rb b/actionpack/lib/action_controller/metal/http_authentication.rb index 283f6413ec..f50394837b 100644 --- a/actionpack/lib/action_controller/metal/http_authentication.rb +++ b/actionpack/lib/action_controller/metal/http_authentication.rb @@ -384,6 +384,8 @@ module ActionController      #      #   RewriteRule ^(.*)$ dispatch.fcgi [E=X-HTTP_AUTHORIZATION:%{HTTP:Authorization},QSA,L]      module Token +      TOKEN_REGEX = /^Token / +      AUTHN_PAIR_DELIMITERS = /(?:,|;|\t+)/        extend self        module ControllerMethods @@ -431,20 +433,34 @@ module ActionController        # Returns an Array of [String, Hash] if a token is present.        # Returns nil if no token is found.        def token_and_options(request) -        if request.authorization.to_s[/^Token (.*)/] -          values = Hash[$1.split(',').map do |value| -            value.strip!                      # remove any spaces between commas and values -            key, value = value.split(/\=\"?/) # split key=value pairs -            if value -              value.chomp!('"')                 # chomp trailing " in value -              value.gsub!(/\\\"/, '"')          # unescape remaining quotes -              [key, value] -            end -          end.compact] -          [values.delete("token"), values.with_indifferent_access] +        authorization_request = request.authorization.to_s +        if authorization_request[TOKEN_REGEX] +          params = token_params_from authorization_request +          [params.shift.last, Hash[params].with_indifferent_access]          end        end +      def token_params_from(auth) +        rewrite_param_values params_array_from raw_params auth +      end + +      # Takes raw_params and turns it into an array of parameters +      def params_array_from(raw_params) +        raw_params.map { |param| param.split %r/=(.+)?/ } +      end + +      # This removes the `"` characters wrapping the value. +      def rewrite_param_values(array_params) +        array_params.each { |param| param.last.gsub! %r/^"|"$/, '' } +      end + +      # This method takes an authorization body and splits up the key-value +      # pairs by the standardized `:`, `;`, or `\t` delimiters defined in +      # `AUTHN_PAIR_DELIMITERS`. +      def raw_params(auth) +        auth.sub(TOKEN_REGEX, '').split /"\s*#{AUTHN_PAIR_DELIMITERS}\s*/ +      end +        # Encodes the given token and options into an Authorization header value.        #        # token   - String token. diff --git a/actionpack/lib/action_controller/metal/redirecting.rb b/actionpack/lib/action_controller/metal/redirecting.rb index b23938e7d9..091facfd8d 100644 --- a/actionpack/lib/action_controller/metal/redirecting.rb +++ b/actionpack/lib/action_controller/metal/redirecting.rb @@ -74,7 +74,7 @@ module ActionController      private        def _extract_redirect_to_status(options, response_status) -        status = if options.is_a?(Hash) && options.key?(:status) +        if options.is_a?(Hash) && options.key?(:status)            Rack::Utils.status_code(options.delete(:status))          elsif response_status.key?(:status)            Rack::Utils.status_code(response_status[:status]) @@ -94,8 +94,7 @@ module ActionController          when String            request.protocol + request.host_with_port + options          when :back -          raise RedirectBackError unless refer = request.headers["Referer"] -          refer +          request.headers["Referer"] or raise RedirectBackError          when Proc            _compute_redirect_to_location options.call          else diff --git a/actionpack/lib/action_controller/metal/strong_parameters.rb b/actionpack/lib/action_controller/metal/strong_parameters.rb index 25e72adbe0..8faa5f8a13 100644 --- a/actionpack/lib/action_controller/metal/strong_parameters.rb +++ b/actionpack/lib/action_controller/metal/strong_parameters.rb @@ -1,5 +1,6 @@  require 'active_support/concern'  require 'active_support/core_ext/hash/indifferent_access' +require 'active_support/core_ext/array/wrap'  require 'active_support/rescuable'  module ActionController | 
