diff options
author | Rafael Mendonça França <rafaelmfranca@gmail.com> | 2014-01-28 16:57:41 -0800 |
---|---|---|
committer | Rafael Mendonça França <rafaelmfranca@gmail.com> | 2014-01-28 16:57:41 -0800 |
commit | 0fcbc659ae819f4021c1725874eb52f99b78901d (patch) | |
tree | aeb8e22f61f21edc695fd2b20f3a98b8d01eae00 /actionpack/lib/action_dispatch/request/utils.rb | |
parent | 2c2792b6bd36b8a4efeaaf2b2b43cea1e85d7f6b (diff) | |
parent | 69ab91ae9396f0101afd13871f179a7f779d3178 (diff) | |
download | rails-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.rb | 13 |
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 |