Class: PlatformSdk::Logging::PiiFormatter

Inherits:
Object
  • Object
show all
Defined in:
lib/platform_sdk/logging/pii_formatter.rb

Overview

Scrubs PII from stdout

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(original_formatter: nil, additional_fields: []) ⇒ PiiFormatter

Returns a new instance of PiiFormatter.



12
13
14
15
16
17
18
# File 'lib/platform_sdk/logging/pii_formatter.rb', line 12

def initialize(original_formatter: nil, additional_fields: [])
  @original_formatter = original_formatter || ::Logger::Formatter.new
  fields = Pii::DEFAULT_FIELDS + additional_fields
  @param_filter = ActiveSupport::ParameterFilter.new(
    fields, mask: Pii::FILTERED
  )
end

Dynamic Method Handling

This class handles dynamic methods through the method_missing method

#method_missing(method, *args, &block) ⇒ Object



29
30
31
32
33
34
35
# File 'lib/platform_sdk/logging/pii_formatter.rb', line 29

def method_missing(method, *args, &block)
  if @original_formatter.respond_to?(method)
    @original_formatter.send(method, *args, &block)
  else
    super
  end
end

Instance Attribute Details

#original_formatterObject (readonly)

Returns the value of attribute original_formatter.



10
11
12
# File 'lib/platform_sdk/logging/pii_formatter.rb', line 10

def original_formatter
  @original_formatter
end

Instance Method Details

#call(severity, timestamp, progname, message) ⇒ Object



20
21
22
23
# File 'lib/platform_sdk/logging/pii_formatter.rb', line 20

def call(severity, timestamp, progname, message)
  scrubbed = scrub_message(message)
  @original_formatter.call(severity, timestamp, progname, scrubbed)
end

#respond_to_missing?(method, include_private = false) ⇒ Boolean

Returns:

  • (Boolean)


25
26
27
# File 'lib/platform_sdk/logging/pii_formatter.rb', line 25

def respond_to_missing?(method, include_private = false)
  @original_formatter.respond_to?(method, include_private) || super
end