lib/raven/processor/sanitizedata.rb in sentry-raven-0.11.2 vs lib/raven/processor/sanitizedata.rb in sentry-raven-0.12.0
- old
+ new
@@ -1,22 +1,24 @@
module Raven
class Processor::SanitizeData < Processor
STRING_MASK = '********'
INT_MASK = 0
- FIELDS_RE = /(authorization|password|passwd|secret|ssn|social(.*)?sec)/i
+ DEFAULT_FIELDS = %w(authorization password passwd secret ssn social(.*)?sec)
VALUES_RE = /^\d{16}$/
def process(value)
+ fields_re = /(#{(DEFAULT_FIELDS + @sanitize_fields).join("|")})/i
+
value.inject(value) do |value,(k,v)|
v = k if v.nil?
if v.is_a?(Hash) || v.is_a?(Array)
process(v)
elsif v.is_a?(String) && (json = parse_json_or_nil(v))
#if this string is actually a json obj, convert and sanitize
value = modify_in_place(value, [k,v], process(json).to_json)
- elsif v.is_a?(Integer) && (VALUES_RE.match(v.to_s) || FIELDS_RE.match(k.to_s))
+ elsif v.is_a?(Integer) && (VALUES_RE.match(v.to_s) || fields_re.match(k.to_s))
value = modify_in_place(value, [k,v], INT_MASK)
- elsif VALUES_RE.match(v.to_s) || FIELDS_RE.match(k.to_s)
+ elsif VALUES_RE.match(v.to_s) || fields_re.match(k.to_s)
value = modify_in_place(value, [k,v], STRING_MASK)
else
value
end
end