aboutsummaryrefslogtreecommitdiffstats
path: root/actionpack/lib/action_controller/metal/strong_parameters.rb
diff options
context:
space:
mode:
authorRafael Mendonça França <rafaelmfranca@gmail.com>2013-01-05 00:22:06 -0800
committerRafael Mendonça França <rafaelmfranca@gmail.com>2013-01-05 00:22:06 -0800
commitdf1f290712225781b1effe4f028aacb98ddb6208 (patch)
tree8e036703936a7635aa65fa4f01c0ecd1c20fa45e /actionpack/lib/action_controller/metal/strong_parameters.rb
parent14f1867661c4f540e80fe39f615cef9678422010 (diff)
parent08578bb40a66aa3c73edab8eef795da6647ed694 (diff)
downloadrails-df1f290712225781b1effe4f028aacb98ddb6208.tar.gz
rails-df1f290712225781b1effe4f028aacb98ddb6208.tar.bz2
rails-df1f290712225781b1effe4f028aacb98ddb6208.zip
Merge pull request #8752 from thomasfedb/master
Exception on unexpected params when enabled.
Diffstat (limited to 'actionpack/lib/action_controller/metal/strong_parameters.rb')
-rw-r--r--actionpack/lib/action_controller/metal/strong_parameters.rb22
1 files changed, 22 insertions, 0 deletions
diff --git a/actionpack/lib/action_controller/metal/strong_parameters.rb b/actionpack/lib/action_controller/metal/strong_parameters.rb
index da380dfbd8..b566dad9eb 100644
--- a/actionpack/lib/action_controller/metal/strong_parameters.rb
+++ b/actionpack/lib/action_controller/metal/strong_parameters.rb
@@ -20,6 +20,20 @@ module ActionController
end
end
+ # Raised when a supplied parameter is not expected.
+ #
+ # params = ActionController::Parameters.new(a: "123", b: "456")
+ # params.permit(:c)
+ # # => ActionController::UnexpectedParameter: found unexpected keys: a, b
+ class UnexpectedParameters < IndexError
+ attr_reader :params
+
+ def initialize(params)
+ @params = params
+ super("found unexpected keys: #{params.join(", ")}")
+ end
+ end
+
# == Action Controller \Parameters
#
# Allows to choose which attributes should be whitelisted for mass updating
@@ -66,6 +80,7 @@ module ActionController
# params["key"] # => "value"
class Parameters < ActiveSupport::HashWithIndifferentAccess
cattr_accessor :permit_all_parameters, instance_accessor: false
+ cattr_accessor :raise_on_unexpected, instance_accessor: false
# Returns a new instance of <tt>ActionController::Parameters</tt>.
# Also, sets the +permitted+ attribute to the default value of
@@ -223,6 +238,13 @@ module ActionController
end
end
+ if Parameters.raise_on_unexpected
+ unexpected_keys = self.keys - params.keys
+ if unexpected_keys.any?
+ raise ActionController::UnexpectedParameters.new(unexpected_keys)
+ end
+ end
+
params.permit!
end