Sha256: e3248c196534f6282dafd41ceacfe0f4ac395f6ac7780d72233f0851607ca38b

Contents?: true

Size: 1.83 KB

Versions: 44

Compression:

Stored size: 1.83 KB

Contents

# encoding: utf-8
require "logstash/namespace"
require "logstash/util"

module LogStash::Util

  # Decorators provides common manipulation on the event data.
  module Decorators
    extend self
    
    @logger = Cabin::Channel.get(LogStash)

    # fields is a hash of field => value
    # where both `field` and `value` can use sprintf syntax.
    def add_fields(fields,event, pluginname)
      fields.each do |field, value|
        field = event.sprintf(field)
        value = Array(value)
        value.each do |v|
          v = event.sprintf(v)
          if event.include?(field)
            # note below that the array field needs to be updated then reassigned to the event.
            # this is important because a construct like event[field] << v will not work
            # in the current Java event implementation. see https://github.com/elastic/logstash/issues/4140
            a = Array(event[field])
            a << v
            event[field] = a
          else
            event[field] = v
          end
          @logger.debug? and @logger.debug("#{pluginname}: adding value to field", :field => field, :value => value)
        end
      end
    end

    # tags is an array of string. sprintf syntax can be used.
    def add_tags(tags, event, pluginname)
      tags.each do |tag|
        tag = event.sprintf(tag)
        @logger.debug? and @logger.debug("#{pluginname}: adding tag", :tag => tag)
        # note below that the tags array field needs to be updated then reassigned to the event.
        # this is important because a construct like event["tags"] << tag will not work
        # in the current Java event implementation. see https://github.com/elastic/logstash/issues/4140
        tags = event["tags"] || []
        tags << tag
        event["tags"] = tags
      end
    end

  end # module LogStash::Util::Decorators

end # module LogStash::Util

Version data entries

44 entries across 44 versions & 3 rubygems

Version Path
logstash-core-5.0.0.alpha2.snapshot1-java lib/logstash/util/decorators.rb
logstash-core-2.3.2-java lib/logstash/util/decorators.rb
logstash-core-2.3.2.snapshot1-java lib/logstash/util/decorators.rb
logstash-core-2.2.4-java lib/logstash/util/decorators.rb
logstash-core-2.3.1-java lib/logstash/util/decorators.rb
logstash-core-2.2.4.snapshot2-java lib/logstash/util/decorators.rb
logstash-core-2.2.4.snapshot1 lib/logstash/util/decorators.rb
logstash-core-2.3.1.snapshot1-java lib/logstash/util/decorators.rb
logstash-core-5.0.0.alpha1-java lib/logstash/util/decorators.rb
logstash-core-5.0.0.alpha1.snapshot2-java lib/logstash/util/decorators.rb
logstash-core-5.0.0.alpha1.snapshot1-java lib/logstash/util/decorators.rb
logstash-core-2.2.3-java lib/logstash/util/decorators.rb
logstash-core-2.3.0-java lib/logstash/util/decorators.rb
logstash-core-2.3.0.snapshot5-java lib/logstash/util/decorators.rb
logstash-core-2.2.3.snapshot2-java lib/logstash/util/decorators.rb
logstash-core-2.3.0.snapshot4-java lib/logstash/util/decorators.rb
logstash-core-2.3.0.snapshot3-java lib/logstash/util/decorators.rb
logstash-core-2.3.0.snapshot1-java lib/logstash/util/decorators.rb
logstash-core-2.2.2-java lib/logstash/util/decorators.rb
logstash-core-2.2.1-java lib/logstash/util/decorators.rb