Class: LogStash::Filters::Grokdiscovery
- Defined in:
- lib/logstash/filters/grokdiscovery.rb
Instance Attribute Summary
Attributes inherited from Base
Instance Method Summary collapse
- #filter(event) ⇒ Object
-
#initialize(config = {}) ⇒ Grokdiscovery
constructor
A new instance of Grokdiscovery.
- #register ⇒ Object
Methods inherited from Base
Constructor Details
#initialize(config = {}) ⇒ Grokdiscovery
Returns a new instance of Grokdiscovery.
8 9 10 11 12 |
# File 'lib/logstash/filters/grokdiscovery.rb', line 8 def initialize(config = {}) super @discover_fields = {} end |
Instance Method Details
#filter(event) ⇒ Object
30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 |
# File 'lib/logstash/filters/grokdiscovery.rb', line 30 def filter(event) # parse it with grok = event. match = false if event.type and @discover_fields.include?(event.type) discover = @discover_fields[event.type] & event.fields.keys discover.each do |field| value = event.fields[field] value = [value] if value.is_a?(String) value.each do |v| pattern = @grok.discover(v) @logger.warn("Trying #{v} => #{pattern}") @grok.compile(pattern) match = @grok.match(v) if match @logger.warn(["Match", match.captures]) event.fields.merge!(match.captures) do |key, oldval, newval| @logger.warn(["Merging #{key}", oldval, newval]) oldval + newval # should both be arrays... end else @logger.warn(["Discovery produced something not matchable?", { :input => v }]) end end # value.each end # discover.each else @logger.info("Unknown type for #{event.source} (type: #{event.type})") @logger.debug(event.to_hash) end @logger.debug(["Event now: ", event.to_hash]) end |
#register ⇒ Object
15 16 17 18 19 20 21 22 23 24 25 26 27 |
# File 'lib/logstash/filters/grokdiscovery.rb', line 15 def register # TODO(sissel): Make patterns files come from the config @config.each do |type, typeconfig| @logger.debug("Registering type with grok: #{type}") @grok = Grok.new Dir.glob("patterns/*").each do |path| @grok.add_patterns_from_file(path) end @discover_fields[type] = typeconfig @logger.debug(["Enabling discovery", { :type => type, :fields => typeconfig }]) @logger.warn(@discover_fields) end # @config.each end |