Sha256: 63c9c426782c3423b78960243ae329ddc89022fd3b37855d27f65763be9cbbaf

Contents?: true

Size: 1.65 KB

Versions: 80

Compression:

Stored size: 1.65 KB

Contents

#
# Fluentd
#
#    Licensed under the Apache License, Version 2.0 (the "License");
#    you may not use this file except in compliance with the License.
#    You may obtain a copy of the License at
#
#        http://www.apache.org/licenses/LICENSE-2.0
#
#    Unless required by applicable law or agreed to in writing, software
#    distributed under the License is distributed on an "AS IS" BASIS,
#    WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
#    See the License for the specific language governing permissions and
#    limitations under the License.
#

require 'fluent/plugin/multi_output'
require 'fluent/config/error'
require 'fluent/event'

module Fluent::Plugin
  class CopyOutput < MultiOutput
    Fluent::Plugin.register_output('copy', self)

    desc 'If true, pass different record to each `store` plugin.'
    config_param :deep_copy, :bool, default: false

    attr_reader :ignore_errors

    def initialize
      super
      @ignore_errors = []
    end

    def configure(conf)
      super

      @stores.each { |store|
        @ignore_errors << (store.arg == 'ignore_error')
      }
    end

    def multi_workers_ready?
      true
    end

    def process(tag, es)
      unless es.repeatable?
        m = Fluent::MultiEventStream.new
        es.each {|time,record|
          m.add(time, record)
        }
        es = m
      end

      outputs.each_with_index do |output, i|
        begin
          output.emit_events(tag, @deep_copy ? es.dup : es)
        rescue => e
          if @ignore_errors[i]
            log.error "ignore emit error", error: e
          else
            raise e
          end
        end
      end
    end
  end
end

Version data entries

80 entries across 80 versions & 1 rubygems

Version Path
fluentd-1.5.0-x86-mingw32 lib/fluent/plugin/out_copy.rb
fluentd-1.5.0-x64-mingw32 lib/fluent/plugin/out_copy.rb
fluentd-1.5.0 lib/fluent/plugin/out_copy.rb
fluentd-1.5.0.rc1 lib/fluent/plugin/out_copy.rb
fluentd-1.4.2-x64-mingw32 lib/fluent/plugin/out_copy.rb
fluentd-1.4.2-x86-mingw32 lib/fluent/plugin/out_copy.rb
fluentd-1.4.2 lib/fluent/plugin/out_copy.rb
fluentd-1.4.1-x86-mingw32 lib/fluent/plugin/out_copy.rb
fluentd-1.4.1-x64-mingw32 lib/fluent/plugin/out_copy.rb
fluentd-1.4.1 lib/fluent/plugin/out_copy.rb
fluentd-1.4.0-x86-mingw32 lib/fluent/plugin/out_copy.rb
fluentd-1.4.0-x64-mingw32 lib/fluent/plugin/out_copy.rb
fluentd-1.4.0 lib/fluent/plugin/out_copy.rb
fluentd-1.3.3-x64-mingw32 lib/fluent/plugin/out_copy.rb
fluentd-1.3.3-x86-mingw32 lib/fluent/plugin/out_copy.rb
fluentd-1.3.3 lib/fluent/plugin/out_copy.rb
fluentd-1.3.2-x86-mingw32 lib/fluent/plugin/out_copy.rb
fluentd-1.3.2-x64-mingw32 lib/fluent/plugin/out_copy.rb
fluentd-1.3.2 lib/fluent/plugin/out_copy.rb
fluentd-1.3.1-x86-mingw32 lib/fluent/plugin/out_copy.rb