Sha256: 992dcbd18f23ec98cddd06f588f1ecc204f53db332d3734aff618956db60e472

Contents?: true

Size: 1.89 KB

Versions: 6

Compression:

Stored size: 1.89 KB

Contents

# frozen_string_literal: true

module Dry
  module Logger
    # Filtering logic
    # Originaly copied from hanami/utils (see Hanami::Logger)
    #
    # @since 0.1.0
    # @api private
    class Filter
      # @since 0.1.0
      # @api private
      def initialize(filters = [])
        @filters = filters
      end

      # @since 0.1.0
      # @api private
      def call(hash)
        _filtered_keys(hash).each do |key|
          *keys, last = _actual_keys(hash, key.split("."))
          keys.inject(hash, :fetch)[last] = "[FILTERED]"
        end

        hash
      end

      private

      # @since 0.1.0
      # @api private
      attr_reader :filters

      # @since 0.1.0
      # @api private
      def _filtered_keys(hash)
        _key_paths(hash).select { |key|
          filters.any? { |filter|
            key =~ /(\.|\A)#{filter}(\.|\z)/
          }
        }
      end

      # @since 0.1.0
      # @api private
      def _key_paths(hash, base = nil)
        hash.inject([]) do |results, (k, v)|
          results + (_key_paths?(v) ? _key_paths(v, _build_path(base, k)) : [_build_path(base, k)])
        end
      end

      # @since 0.1.0
      # @api private
      def _build_path(base, key)
        [base, key.to_s].compact.join(".")
      end

      # @since 0.1.0
      # @api private
      def _actual_keys(hash, keys)
        search_in = hash

        keys.inject([]) do |res, key|
          correct_key = search_in.key?(key.to_sym) ? key.to_sym : key
          search_in = search_in[correct_key]
          res + [correct_key]
        end
      end

      # Check if the given value can be iterated (`Enumerable`) and that isn't a `File`.
      # This is useful to detect closed `Tempfiles`.
      #
      # @since 0.1.0
      # @api private
      #
      # @see https://github.com/hanami/utils/pull/342
      def _key_paths?(value)
        value.is_a?(Enumerable) && !value.is_a?(File)
      end
    end
  end
end

Version data entries

6 entries across 6 versions & 1 rubygems

Version Path
dry-logger-1.0.3 lib/dry/logger/filter.rb
dry-logger-1.0.2 lib/dry/logger/filter.rb
dry-logger-1.0.1 lib/dry/logger/filter.rb
dry-logger-1.0.0 lib/dry/logger/filter.rb
dry-logger-1.0.0.rc2 lib/dry/logger/filter.rb
dry-logger-1.0.0.rc1 lib/dry/logger/filter.rb