Sha256: 5e7ab8fc1dee2fba4fd8a020e9972231d4432d52d9f7c2d36de19a2f0cce0c88
Contents?: true
Size: 1.83 KB
Versions: 3
Compression:
Stored size: 1.83 KB
Contents
# frozen_string_literal: true module ElasticAPM module Transport module Filters # @api private class SecretsFilter FILTERED = '[FILTERED]' KEY_FILTERS = [ /passw(or)?d/i, /auth/i, /^pw$/, /secret/i, /token/i, /api[-._]?key/i, /session[-._]?id/i ].freeze VALUE_FILTERS = [ # (probably) credit card number /^\d{4}[- ]?\d{4}[- ]?\d{4}[- ]?\d{4}$/ ].freeze def initialize(config) @config = config @key_filters = KEY_FILTERS + config.custom_key_filters end def call(payload) strip_from! payload.dig(:transaction, :context, :request, :headers) strip_from! payload.dig(:transaction, :context, :response, :headers) strip_from! payload.dig(:error, :context, :request, :headers) strip_from! payload.dig(:error, :context, :response, :headers) strip_from! payload.dig(:transaction, :context, :request, :body) payload end # rubocop:disable Metrics/MethodLength, Metrics/CyclomaticComplexity def strip_from!(obj) return unless obj && obj.is_a?(Hash) obj.each do |k, v| if filter_key?(k) next obj[k] = FILTERED end case v when Hash strip_from!(v) when String if filter_value?(v) obj[k] = FILTERED end end end end # rubocop:enable Metrics/MethodLength, Metrics/CyclomaticComplexity def filter_key?(key) @key_filters.any? { |regex| key.match regex } end def filter_value?(value) VALUE_FILTERS.any? { |regex| value.match regex } end end end end end
Version data entries
3 entries across 3 versions & 1 rubygems