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 |