aboutsummaryrefslogtreecommitdiffstats
path: root/actionpack
diff options
context:
space:
mode:
authorPrem Sichanugrist <prem@thoughtbot.com>2014-12-12 17:30:05 +0700
committerPrem Sichanugrist <prem@thoughtbot.com>2014-12-12 17:30:05 +0700
commit0d975e289de59f86dadcf7f1189ce875eab40b74 (patch)
treeaab4a1f072c31fb97ab9d31a1703471e4ecf58d8 /actionpack
parentb5001ea4d82d5bff21510b1315ca0db2fdaa186b (diff)
downloadrails-0d975e289de59f86dadcf7f1189ce875eab40b74.tar.gz
rails-0d975e289de59f86dadcf7f1189ce875eab40b74.tar.bz2
rails-0d975e289de59f86dadcf7f1189ce875eab40b74.zip
Make AC::Params.permit_all_parameters thread safe
As discussed in #16299[1], this attribute is not thread safe and could potentially create a security issue. [1]: https://github.com/rails/rails/pull/16299#discussion_r15424533
Diffstat (limited to 'actionpack')
-rw-r--r--actionpack/lib/action_controller/metal/strong_parameters.rb11
1 files changed, 10 insertions, 1 deletions
diff --git a/actionpack/lib/action_controller/metal/strong_parameters.rb b/actionpack/lib/action_controller/metal/strong_parameters.rb
index a5ee1e2159..48ca8ac965 100644
--- a/actionpack/lib/action_controller/metal/strong_parameters.rb
+++ b/actionpack/lib/action_controller/metal/strong_parameters.rb
@@ -100,7 +100,6 @@ module ActionController
# params[:key] # => "value"
# params["key"] # => "value"
class Parameters < ActiveSupport::HashWithIndifferentAccess
- cattr_accessor :permit_all_parameters, instance_accessor: false
cattr_accessor :action_on_unpermitted_parameters, instance_accessor: false
# By default, never raise an UnpermittedParameters exception if these
@@ -123,6 +122,16 @@ module ActionController
always_permitted_parameters
end
+ # Returns the value of +permit_all_parameters+.
+ def self.permit_all_parameters
+ Thread.current[:action_controller_permit_all_parameters]
+ end
+
+ # Sets the value of +permit_all_parameters+.
+ def self.permit_all_parameters=(value)
+ Thread.current[:action_controller_permit_all_parameters] = value
+ end
+
# Returns a new instance of <tt>ActionController::Parameters</tt>.
# Also, sets the +permitted+ attribute to the default value of
# <tt>ActionController::Parameters.permit_all_parameters</tt>.