Sha256: 5694e936f137cdea7a3870af219b1c13381a35f5f65556caf501add864de1bed

Contents?: true

Size: 1.11 KB

Versions: 4

Compression:

Stored size: 1.11 KB

Contents

# frozen_string_literal: true

module BingAdsRubySdk
  class LogMessage
    def initialize(message)
      @message = message
    end

    def to_s
      return message unless message_is_xml
      return message unless filters.any? || pretty_print

      document = Nokogiri::XML(message)
      document = apply_filter(document) if filters.any?
      document.to_xml(nokogiri_options)
    end

    FILTERED = "***FILTERED***"

    private

    attr_reader :message

    def message_is_xml
      message =~ /^</
    end

    def apply_filter(document)
      return document unless document.errors.empty?

      filters.each do |filter|
        apply_filter! document, filter
      end

      document
    end

    def apply_filter!(document, filter)
      document.xpath("//*[local-name()='#{filter}']").each do |node|
        node.content = FILTERED
      end
    end

    def nokogiri_options
      pretty_print ? {indent: 2} : {save_with: Nokogiri::XML::Node::SaveOptions::AS_XML}
    end

    def pretty_print
      BingAdsRubySdk.config.pretty_print_xml
    end

    def filters
      BingAdsRubySdk.config.filters
    end
  end
end

Version data entries

4 entries across 4 versions & 1 rubygems

Version Path
bing_ads_ruby_sdk-1.7 lib/bing_ads_ruby_sdk/log_message.rb
bing_ads_ruby_sdk-1.6 lib/bing_ads_ruby_sdk/log_message.rb
bing_ads_ruby_sdk-1.5.2 lib/bing_ads_ruby_sdk/log_message.rb
bing_ads_ruby_sdk-1.5.0 lib/bing_ads_ruby_sdk/log_message.rb