Sha256: c7fa1ae4ee704d05b09e4be994d803e9ad2d23a7aa39bc0fc79a2582dcd529fe
Contents?: true
Size: 1.09 KB
Versions: 1
Compression:
Stored size: 1.09 KB
Contents
require "logstash/codecs/base" require "logstash/codecs/line" require "logstash/util" class LogStash::Codecs::EDNLines < LogStash::Codecs::Base config_name "edn_lines" milestone 1 def register require "edn" end public def initialize(params={}) super(params) @lines = LogStash::Codecs::Line.new end public def decode(data) @lines.decode(data) do |event| begin yield LogStash::Event.new(EDN.read(event["message"])) rescue => e @logger.warn("EDN parse failure. Falling back to plain-text", :error => e, :data => data) yield LogStash::Event.new("message" => data) end end end public def encode(event) # use normalize to make sure returned Hash is pure Ruby for # #to_edn which relies on pure Ruby object recognition data = LogStash::Util.normalize(event.to_hash) # timestamp is serialized as a iso8601 string # merge to avoid modifying data which could have side effects if multiple outputs @on_event.call(event, data.merge(LogStash::Event::TIMESTAMP => event.timestamp.to_iso8601).to_edn + NL) end end
Version data entries
1 entries across 1 versions & 1 rubygems
Version | Path |
---|---|
logstash-codec-edn_lines-0.1.3 | lib/logstash/codecs/edn_lines.rb |