Sha256: b61daad9a65e1887de0fb075133eef3879ea554c8966564e136b93e574603264
Contents?: true
Size: 1.84 KB
Versions: 14
Compression:
Stored size: 1.84 KB
Contents
require 'logstash-logger/device/base' module LogStashLogger module Device DEFAULT_TYPE = :udp autoload :Base, 'logstash-logger/device/base' autoload :Connectable, 'logstash-logger/device/connectable' autoload :Socket, 'logstash-logger/device/socket' autoload :UDP, 'logstash-logger/device/udp' autoload :TCP, 'logstash-logger/device/tcp' autoload :Unix, 'logstash-logger/device/unix' autoload :Redis, 'logstash-logger/device/redis' autoload :Kafka, 'logstash-logger/device/kafka' autoload :File, 'logstash-logger/device/file' autoload :IO, 'logstash-logger/device/io' autoload :Stdout, 'logstash-logger/device/stdout' autoload :Stderr, 'logstash-logger/device/stderr' autoload :Balancer, 'logstash-logger/device/balancer' autoload :MultiDelegator, 'logstash-logger/device/multi_delegator' def self.new(opts) opts = opts.dup build_device(opts) end def self.build_device(opts) if parsed_uri_opts = parse_uri_config(opts) opts.delete(:uri) opts.merge!(parsed_uri_opts) end type = opts.delete(:type) || DEFAULT_TYPE device_klass_for(type).new(opts) end def self.parse_uri_config(opts) if uri = opts[:uri] parsed = ::URI.parse(uri) {type: parsed.scheme, host: parsed.host, port: parsed.port, path: parsed.path} end end def self.device_klass_for(type) case type.to_sym when :udp then UDP when :tcp then TCP when :unix then Unix when :file then File when :redis then Redis when :kafka then Kafka when :io then IO when :stdout then Stdout when :stderr then Stderr when :multi_delegator then MultiDelegator when :balancer then Balancer else fail ArgumentError, 'Invalid device type' end end end end
Version data entries
14 entries across 14 versions & 1 rubygems