class Savon::LogMessage
Public Class Methods
new(message, filters = [], pretty_print = false)
click to toggle source
# File lib/savon/log_message.rb, line 6 def initialize(message, filters = [], pretty_print = false) @message = message @filters = filters @pretty_print = pretty_print end
Public Instance Methods
to_s()
click to toggle source
# File lib/savon/log_message.rb, line 12 def to_s message_is_xml = @message =~ /^</ has_filters = @filters.any? pretty_print = @pretty_print return @message unless message_is_xml return @message unless has_filters || pretty_print document = Nokogiri.XML(@message) document = apply_filter(document) if has_filters document.to_xml(nokogiri_options) end
Private Instance Methods
apply_filter(document)
click to toggle source
# File lib/savon/log_message.rb, line 27 def apply_filter(document) return document unless document.errors.empty? @filters.each do |filter| apply_filter! document, filter end document end
apply_filter!(document, filter)
click to toggle source
# File lib/savon/log_message.rb, line 37 def apply_filter!(document, filter) if filter.instance_of? Proc filter.call document else document.xpath("//*[local-name()='#{filter}']").each do |node| node.content = "***FILTERED***" end end end
nokogiri_options()
click to toggle source
# File lib/savon/log_message.rb, line 47 def nokogiri_options @pretty_print ? { :indent => 2 } : {} end