Sha256: 75cf397294e3b1476c888b989c61bbf5a5ca512318b5a72f4f286f70ecea11c4

Contents?: true

Size: 1.67 KB

Versions: 1

Compression:

Stored size: 1.67 KB

Contents

require 'nori'

module Fluent
  class XmlFilter < Filter
    Fluent::Plugin.register_filter('xml_simple', self)

    config_param :fields, :string

    config_param :try_convert_times, :bool, :default => true # try to convert values in hash to times
    config_param :time_format, :string, :default => '%F'
    config_param :field_name_postfix, :string, :default => 'hash' # if set will create hash in new field with postfix (xml => xml_hash)

    def configure(conf)
      super

      raise ConfigError, "'Fields' is required" if self.fields.nil?

      self.fields = self.fields.split(',')

      raise ConfigError, "'Fields' must contain at least one key" if self.fields.length < 1
    end

    def start
      super

      @parser = Nori.new(:advanced_typecasting => false)
    end

    def shutdown
      super

      @parser = nil
    end

    def filter(tag, time, record)
      self.fields.each { |field|
        if record.key?(field)
          field_name = field

          if self.field_name_postfix
            field_name = [field, self.field_name_postfix].join '_'
          end

          hash = @parser.parse(record[field])

          record[field_name] = self.try_convert_times ? convert_times(hash) : hash
        end
      }

      record
    end

    private

    def convert_times(hash)
      hash.each { |key, value|
        value.class == Hash ? convert_times(value) : try_to_convert(value) { |x|
          self.time_format ? Time.strptime(x, self.time_format) : Time.parse(x)
        }
      }
    end

    def try_to_convert(value, &block)
      block.call(value)
    rescue Exception => e
      $log.debug "Cannot convert time: #{e.message}\nTrace: #{e.backtrace.to_s}"
    end
  end
end

Version data entries

1 entries across 1 versions & 1 rubygems

Version Path
fluent-plugin-xml-simple-filter-0.0.9 lib/fluent/plugin/filter_xml_simple.rb