Sha256: 218c7a990ae4457e09ce492105146769bd40954562202ef953c10081e1959109
Contents?: true
Size: 1.63 KB
Versions: 1
Compression:
Stored size: 1.63 KB
Contents
# frozen_string_literal: true require 'fluent/plugin/in_http' module Fluent module Plugin class HerokuSyslogHttpInput < HttpInput Fluent::Plugin.register_input('heroku_syslog_http', self) config_section :parse do config_set_default :@type, 'heroku_syslog_http' end config_param :drain_ids, :array, default: nil private def parse_params_with_parser(params) content = params[EVENT_RECORD_PARAMETER] raise "'#{EVENT_RECORD_PARAMETER}' parameter is required" unless content messages = [] while payload = content.match(/^([0-9]+) (.*)$/) do length = payload[1].to_i raise "Invalid message length specified: #{length}" unless payload[2].size >= length messages << payload[2][0...length] content = payload[2][length..-1] || '' end content << content raise "#{content.size} bytes left in payload" unless content.size == 0 records = [] messages.each do |msg| @parser.parse(msg) do |time, record| raise "Could not parse event: #{content}" if record.nil? record['syslog.timestamp'] ||= Time.at(time).utc.strftime('%Y-%m-%dT%H:%M:%S%z') record['logplex.drain_id'] = params['HTTP_LOGPLEX_DRAIN_TOKEN'] record['logplex.frame_id'] = params['HTTP_LOGPLEX_FRAME_ID'] unless @drain_ids.nil? || @drain_ids.include?(record['logplex.drain_id']) log.warn "drain_id not match: #{msg.inspect}" next end records << record end end [nil, records] end end end end
Version data entries
1 entries across 1 versions & 1 rubygems
Version | Path |
---|---|
fluent-plugin-heroku-syslog-http-0.2.1 | lib/fluent/plugin/in_heroku_syslog_http.rb |