aboutsummaryrefslogtreecommitdiffstats
path: root/actionpack/lib/action_dispatch/request/utils.rb
diff options
context:
space:
mode:
authorRafael Mendonça França <rafaelmfranca@gmail.com>2014-01-28 16:57:41 -0800
committerRafael Mendonça França <rafaelmfranca@gmail.com>2014-01-28 16:57:41 -0800
commit0fcbc659ae819f4021c1725874eb52f99b78901d (patch)
treeaeb8e22f61f21edc695fd2b20f3a98b8d01eae00 /actionpack/lib/action_dispatch/request/utils.rb
parent2c2792b6bd36b8a4efeaaf2b2b43cea1e85d7f6b (diff)
parent69ab91ae9396f0101afd13871f179a7f779d3178 (diff)
downloadrails-0fcbc659ae819f4021c1725874eb52f99b78901d.tar.gz
rails-0fcbc659ae819f4021c1725874eb52f99b78901d.tar.bz2
rails-0fcbc659ae819f4021c1725874eb52f99b78901d.zip
Merge pull request #13813 from lukesarnacki/log-deep-munge
Log for which keys values were set to nil in deep_munge
Diffstat (limited to 'actionpack/lib/action_dispatch/request/utils.rb')
-rw-r--r--actionpack/lib/action_dispatch/request/utils.rb13
1 files changed, 9 insertions, 4 deletions
diff --git a/actionpack/lib/action_dispatch/request/utils.rb b/actionpack/lib/action_dispatch/request/utils.rb
index a6dca9741c..9d4f1aa3c5 100644
--- a/actionpack/lib/action_dispatch/request/utils.rb
+++ b/actionpack/lib/action_dispatch/request/utils.rb
@@ -7,18 +7,23 @@ module ActionDispatch
class << self
# Remove nils from the params hash
- def deep_munge(hash)
+ def deep_munge(hash, keys = [])
return hash unless perform_deep_munge
hash.each do |k, v|
+ keys << k
case v
when Array
- v.grep(Hash) { |x| deep_munge(x) }
+ v.grep(Hash) { |x| deep_munge(x, keys) }
v.compact!
- hash[k] = nil if v.empty?
+ if v.empty?
+ hash[k] = nil
+ ActiveSupport::Notifications.instrument("deep_munge.action_controller", keys: keys)
+ end
when Hash
- deep_munge(v)
+ deep_munge(v, keys)
end
+ keys.pop
end
hash