logstash-input-zeromq 0.1.0 → 0.1.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
checksums.yaml CHANGED
@@ -1,15 +1,7 @@
1
1
  ---
2
- !binary "U0hBMQ==":
3
- metadata.gz: !binary |-
4
- OTRiZTVkZWNiNjFkNDExODMxYTBkNGRkMjY3YTEyNmFlNjk5NDQ5Mw==
5
- data.tar.gz: !binary |-
6
- MjdmZjFmOGRlOGNiMzFjNDRiNjhkNWFjYWVhYzU0NzZmNzU4NDlhNg==
2
+ SHA1:
3
+ metadata.gz: ab6c08b555cf8317479b8aedf782e2e197529677
4
+ data.tar.gz: 992f5fb22f2fa32603f662c965f628a5a5f7d574
7
5
  SHA512:
8
- metadata.gz: !binary |-
9
- ODRmMDE1NDhhZjEyNmVkMDg0ZTRjMzk3YTFjZGUyMjBiYmQ3ZGU1OGI1YjU2
10
- ODVhZmQxYmFlYWEyOTMzNjY2YjljZWZmZjQxOTM5MDZhZTZiMWZkMTQ5M2Jh
11
- ZjI5MTliMDQ5MDA0ZDE2N2M2ZTUyMDU0NWRmNjA4MDg3Njg3NzQ=
12
- data.tar.gz: !binary |-
13
- YmM2OTU0YThlMmIxZDM5YTg0YzliYmViMDA1YTFkOTRlMWNhNDA5MmQ0MDE0
14
- NzIxYTBhYzBhYTNkOWU5MjNmYjAwYWE2MzVkYjhjOWY0ZTBiNDFlNDk0ZGI5
15
- YjJjY2JkYjE3MmQ0MWExNDNhNGYwZmZjMjgyNzkwNTdlZjhiZjI=
6
+ metadata.gz: 3c2bf87a849791e1917bf9d600e77f69d6dad10e10ac99c99f3b293c93331941d9bab85e60ccf664ba752357f60ee4d1eaf5182b7f2c16bd709bc889cc0a5a7c
7
+ data.tar.gz: c9cd8613c130d1759043ab0d84604539c304053d5f4c4d98fc2b96051c0b3a2ea3f6abdead9423acf6e98fe5180c8690547d90f62cf39a63ff5bb9031bcf8d48
data/Gemfile CHANGED
@@ -1,4 +1,3 @@
1
- source 'http://rubygems.org'
2
- gem 'rake'
3
- gem 'gem_publisher'
4
- gem 'archive-tar-minitar'
1
+ source 'https://rubygems.org'
2
+ gemspec
3
+ gem "logstash", :github => "elasticsearch/logstash", :branch => "1.5"
data/Rakefile CHANGED
@@ -4,3 +4,4 @@ task :default do
4
4
  system("rake -T")
5
5
  end
6
6
 
7
+ require "logstash/devutils/rake"
@@ -8,7 +8,7 @@ require "socket"
8
8
  # You need to have the 0mq 2.1.x library installed to be able to use
9
9
  # this input plugin.
10
10
  #
11
- # The default settings will create a subscriber binding to tcp://127.0.0.1:2120
11
+ # The default settings will create a subscriber binding to `tcp://127.0.0.1:2120`
12
12
  # waiting for connecting publishers.
13
13
  #
14
14
  class LogStash::Inputs::ZeroMQ < LogStash::Inputs::Base
@@ -27,18 +27,19 @@ class LogStash::Inputs::ZeroMQ < LogStash::Inputs::Base
27
27
 
28
28
  # 0mq topology
29
29
  # The default logstash topologies work as follows:
30
+ #
30
31
  # * pushpull - inputs are pull, outputs are push
31
32
  # * pubsub - inputs are subscribers, outputs are publishers
32
33
  # * pair - inputs are clients, inputs are servers
33
34
  #
34
35
  # If the predefined topology flows don't work for you,
35
- # you can change the 'mode' setting
36
+ # you can change the `mode` setting
36
37
  # TODO (lusis) add req/rep MAYBE
37
38
  # TODO (lusis) add router/dealer
38
39
  config :topology, :validate => ["pushpull", "pubsub", "pair"], :required => true
39
40
 
40
41
  # 0mq topic
41
- # This is used for the 'pubsub' topology only
42
+ # This is used for the `pubsub` topology only
42
43
  # On inputs, this allows you to filter messages by topic
43
44
  # On outputs, this allows you to tag a message for routing
44
45
  # NOTE: ZeroMQ does subscriber side filtering.
@@ -54,20 +55,21 @@ class LogStash::Inputs::ZeroMQ < LogStash::Inputs::Base
54
55
  # sender
55
56
  # overrides the sender to
56
57
  # set the source of the event
57
- # default is "zmq+topology://type/"
58
+ # default is `zmq+topology://type/`
58
59
  config :sender, :validate => :string
59
60
 
60
61
  # 0mq socket options
61
- # This exposes zmq_setsockopt
62
+ # This exposes `zmq_setsockopt`
62
63
  # for advanced tuning
63
64
  # see http://api.zeromq.org/2-1:zmq-setsockopt for details
64
65
  #
65
66
  # This is where you would set values like:
66
- # ZMQ::HWM - high water mark
67
- # ZMQ::IDENTITY - named queues
68
- # ZMQ::SWAP_SIZE - space for disk overflow
69
67
  #
70
- # example: sockopt => ["ZMQ::HWM", 50, "ZMQ::IDENTITY", "my_named_queue"]
68
+ # * `ZMQ::HWM` - high water mark
69
+ # * `ZMQ::IDENTITY` - named queues
70
+ # * `ZMQ::SWAP_SIZE` - space for disk overflow
71
+ #
72
+ # example: `sockopt => ["ZMQ::HWM", 50, "ZMQ::IDENTITY", "my_named_queue"]`
71
73
  config :sockopt, :validate => :hash
72
74
 
73
75
  public
@@ -1,13 +1,13 @@
1
1
  Gem::Specification.new do |s|
2
2
 
3
3
  s.name = 'logstash-input-zeromq'
4
- s.version = '0.1.0'
4
+ s.version = '0.1.1'
5
5
  s.licenses = ['Apache License (2.0)']
6
6
  s.summary = "$summary"
7
- s.description = "$description"
7
+ s.description = "This gem is a logstash plugin required to be installed on top of the Logstash core pipeline using $LS_HOME/bin/plugin install gemname. This gem is not a stand-alone program"
8
8
  s.authors = ["Elasticsearch"]
9
- s.email = 'richard.pijnenburg@elasticsearch.com'
10
- s.homepage = "http://logstash.net/"
9
+ s.email = 'info@elasticsearch.com'
10
+ s.homepage = "http://www.elasticsearch.org/guide/en/logstash/current/index.html"
11
11
  s.require_paths = ["lib"]
12
12
 
13
13
  # Files
@@ -17,12 +17,13 @@ Gem::Specification.new do |s|
17
17
  s.test_files = s.files.grep(%r{^(test|spec|features)/})
18
18
 
19
19
  # Special flag to let us know this is actually a logstash plugin
20
- s.metadata = { "logstash_plugin" => "true", "group" => "input" }
20
+ s.metadata = { "logstash_plugin" => "true", "logstash_group" => "input" }
21
21
 
22
22
  # Gem dependencies
23
23
  s.add_runtime_dependency 'logstash', '>= 1.4.0', '< 2.0.0'
24
24
 
25
25
  s.add_runtime_dependency 'logstash-codec-json'
26
26
  s.add_runtime_dependency 'ffi-rzmq'
27
+ s.add_development_dependency 'logstash-devutils'
27
28
  end
28
29
 
@@ -1 +1 @@
1
- require 'spec_helper'
1
+ require "logstash/devutils/rspec/spec_helper"
metadata CHANGED
@@ -1,65 +1,79 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: logstash-input-zeromq
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.1.0
4
+ version: 0.1.1
5
5
  platform: ruby
6
6
  authors:
7
7
  - Elasticsearch
8
- autorequire:
8
+ autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2014-11-05 00:00:00.000000000 Z
11
+ date: 2014-11-19 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: logstash
15
- requirement: !ruby/object:Gem::Requirement
15
+ version_requirements: !ruby/object:Gem::Requirement
16
16
  requirements:
17
- - - ! '>='
17
+ - - '>='
18
18
  - !ruby/object:Gem::Version
19
19
  version: 1.4.0
20
20
  - - <
21
21
  - !ruby/object:Gem::Version
22
22
  version: 2.0.0
23
- type: :runtime
24
- prerelease: false
25
- version_requirements: !ruby/object:Gem::Requirement
23
+ requirement: !ruby/object:Gem::Requirement
26
24
  requirements:
27
- - - ! '>='
25
+ - - '>='
28
26
  - !ruby/object:Gem::Version
29
27
  version: 1.4.0
30
28
  - - <
31
29
  - !ruby/object:Gem::Version
32
30
  version: 2.0.0
31
+ prerelease: false
32
+ type: :runtime
33
33
  - !ruby/object:Gem::Dependency
34
34
  name: logstash-codec-json
35
+ version_requirements: !ruby/object:Gem::Requirement
36
+ requirements:
37
+ - - '>='
38
+ - !ruby/object:Gem::Version
39
+ version: '0'
35
40
  requirement: !ruby/object:Gem::Requirement
36
41
  requirements:
37
- - - ! '>='
42
+ - - '>='
38
43
  - !ruby/object:Gem::Version
39
44
  version: '0'
40
- type: :runtime
41
45
  prerelease: false
46
+ type: :runtime
47
+ - !ruby/object:Gem::Dependency
48
+ name: ffi-rzmq
42
49
  version_requirements: !ruby/object:Gem::Requirement
43
50
  requirements:
44
- - - ! '>='
51
+ - - '>='
45
52
  - !ruby/object:Gem::Version
46
53
  version: '0'
47
- - !ruby/object:Gem::Dependency
48
- name: ffi-rzmq
49
54
  requirement: !ruby/object:Gem::Requirement
50
55
  requirements:
51
- - - ! '>='
56
+ - - '>='
52
57
  - !ruby/object:Gem::Version
53
58
  version: '0'
54
- type: :runtime
55
59
  prerelease: false
60
+ type: :runtime
61
+ - !ruby/object:Gem::Dependency
62
+ name: logstash-devutils
56
63
  version_requirements: !ruby/object:Gem::Requirement
57
64
  requirements:
58
- - - ! '>='
65
+ - - '>='
66
+ - !ruby/object:Gem::Version
67
+ version: '0'
68
+ requirement: !ruby/object:Gem::Requirement
69
+ requirements:
70
+ - - '>='
59
71
  - !ruby/object:Gem::Version
60
72
  version: '0'
61
- description: $description
62
- email: richard.pijnenburg@elasticsearch.com
73
+ prerelease: false
74
+ type: :development
75
+ description: This gem is a logstash plugin required to be installed on top of the Logstash core pipeline using $LS_HOME/bin/plugin install gemname. This gem is not a stand-alone program
76
+ email: info@elasticsearch.com
63
77
  executables: []
64
78
  extensions: []
65
79
  extra_rdoc_files: []
@@ -71,33 +85,31 @@ files:
71
85
  - lib/logstash/inputs/zeromq.rb
72
86
  - lib/logstash/util/zeromq.rb
73
87
  - logstash-input-zeromq.gemspec
74
- - rakelib/publish.rake
75
- - rakelib/vendor.rake
76
88
  - spec/inputs/zeromq_spec.rb
77
- homepage: http://logstash.net/
89
+ homepage: http://www.elasticsearch.org/guide/en/logstash/current/index.html
78
90
  licenses:
79
91
  - Apache License (2.0)
80
92
  metadata:
81
93
  logstash_plugin: 'true'
82
- group: input
83
- post_install_message:
94
+ logstash_group: input
95
+ post_install_message:
84
96
  rdoc_options: []
85
97
  require_paths:
86
98
  - lib
87
99
  required_ruby_version: !ruby/object:Gem::Requirement
88
100
  requirements:
89
- - - ! '>='
101
+ - - '>='
90
102
  - !ruby/object:Gem::Version
91
103
  version: '0'
92
104
  required_rubygems_version: !ruby/object:Gem::Requirement
93
105
  requirements:
94
- - - ! '>='
106
+ - - '>='
95
107
  - !ruby/object:Gem::Version
96
108
  version: '0'
97
109
  requirements: []
98
- rubyforge_project:
99
- rubygems_version: 2.4.1
100
- signing_key:
110
+ rubyforge_project:
111
+ rubygems_version: 2.2.2
112
+ signing_key:
101
113
  specification_version: 4
102
114
  summary: $summary
103
115
  test_files:
data/rakelib/publish.rake DELETED
@@ -1,9 +0,0 @@
1
- require "gem_publisher"
2
-
3
- desc "Publish gem to RubyGems.org"
4
- task :publish_gem do |t|
5
- gem_file = Dir.glob(File.expand_path('../*.gemspec',File.dirname(__FILE__))).first
6
- gem = GemPublisher.publish_if_updated(gem_file, :rubygems)
7
- puts "Published #{gem}" if gem
8
- end
9
-
data/rakelib/vendor.rake DELETED
@@ -1,169 +0,0 @@
1
- require "net/http"
2
- require "uri"
3
- require "digest/sha1"
4
-
5
- def vendor(*args)
6
- return File.join("vendor", *args)
7
- end
8
-
9
- directory "vendor/" => ["vendor"] do |task, args|
10
- mkdir task.name
11
- end
12
-
13
- def fetch(url, sha1, output)
14
-
15
- puts "Downloading #{url}"
16
- actual_sha1 = download(url, output)
17
-
18
- if actual_sha1 != sha1
19
- fail "SHA1 does not match (expected '#{sha1}' but got '#{actual_sha1}')"
20
- end
21
- end # def fetch
22
-
23
- def file_fetch(url, sha1)
24
- filename = File.basename( URI(url).path )
25
- output = "vendor/#{filename}"
26
- task output => [ "vendor/" ] do
27
- begin
28
- actual_sha1 = file_sha1(output)
29
- if actual_sha1 != sha1
30
- fetch(url, sha1, output)
31
- end
32
- rescue Errno::ENOENT
33
- fetch(url, sha1, output)
34
- end
35
- end.invoke
36
-
37
- return output
38
- end
39
-
40
- def file_sha1(path)
41
- digest = Digest::SHA1.new
42
- fd = File.new(path, "r")
43
- while true
44
- begin
45
- digest << fd.sysread(16384)
46
- rescue EOFError
47
- break
48
- end
49
- end
50
- return digest.hexdigest
51
- ensure
52
- fd.close if fd
53
- end
54
-
55
- def download(url, output)
56
- uri = URI(url)
57
- digest = Digest::SHA1.new
58
- tmp = "#{output}.tmp"
59
- Net::HTTP.start(uri.host, uri.port, :use_ssl => (uri.scheme == "https")) do |http|
60
- request = Net::HTTP::Get.new(uri.path)
61
- http.request(request) do |response|
62
- fail "HTTP fetch failed for #{url}. #{response}" if [200, 301].include?(response.code)
63
- size = (response["content-length"].to_i || -1).to_f
64
- count = 0
65
- File.open(tmp, "w") do |fd|
66
- response.read_body do |chunk|
67
- fd.write(chunk)
68
- digest << chunk
69
- if size > 0 && $stdout.tty?
70
- count += chunk.bytesize
71
- $stdout.write(sprintf("\r%0.2f%%", count/size * 100))
72
- end
73
- end
74
- end
75
- $stdout.write("\r \r") if $stdout.tty?
76
- end
77
- end
78
-
79
- File.rename(tmp, output)
80
-
81
- return digest.hexdigest
82
- rescue SocketError => e
83
- puts "Failure while downloading #{url}: #{e}"
84
- raise
85
- ensure
86
- File.unlink(tmp) if File.exist?(tmp)
87
- end # def download
88
-
89
- def untar(tarball, &block)
90
- require "archive/tar/minitar"
91
- tgz = Zlib::GzipReader.new(File.open(tarball))
92
- # Pull out typesdb
93
- tar = Archive::Tar::Minitar::Input.open(tgz)
94
- tar.each do |entry|
95
- path = block.call(entry)
96
- next if path.nil?
97
- parent = File.dirname(path)
98
-
99
- mkdir_p parent unless File.directory?(parent)
100
-
101
- # Skip this file if the output file is the same size
102
- if entry.directory?
103
- mkdir path unless File.directory?(path)
104
- else
105
- entry_mode = entry.instance_eval { @mode } & 0777
106
- if File.exists?(path)
107
- stat = File.stat(path)
108
- # TODO(sissel): Submit a patch to archive-tar-minitar upstream to
109
- # expose headers in the entry.
110
- entry_size = entry.instance_eval { @size }
111
- # If file sizes are same, skip writing.
112
- next if stat.size == entry_size && (stat.mode & 0777) == entry_mode
113
- end
114
- puts "Extracting #{entry.full_name} from #{tarball} #{entry_mode.to_s(8)}"
115
- File.open(path, "w") do |fd|
116
- # eof? check lets us skip empty files. Necessary because the API provided by
117
- # Archive::Tar::Minitar::Reader::EntryStream only mostly acts like an
118
- # IO object. Something about empty files in this EntryStream causes
119
- # IO.copy_stream to throw "can't convert nil into String" on JRuby
120
- # TODO(sissel): File a bug about this.
121
- while !entry.eof?
122
- chunk = entry.read(16384)
123
- fd.write(chunk)
124
- end
125
- #IO.copy_stream(entry, fd)
126
- end
127
- File.chmod(entry_mode, path)
128
- end
129
- end
130
- tar.close
131
- File.unlink(tarball) if File.file?(tarball)
132
- end # def untar
133
-
134
- def ungz(file)
135
-
136
- outpath = file.gsub('.gz', '')
137
- tgz = Zlib::GzipReader.new(File.open(file))
138
- begin
139
- File.open(outpath, "w") do |out|
140
- IO::copy_stream(tgz, out)
141
- end
142
- File.unlink(file)
143
- rescue
144
- File.unlink(outpath) if File.file?(outpath)
145
- raise
146
- end
147
- tgz.close
148
- end
149
-
150
- desc "Process any vendor files required for this plugin"
151
- task "vendor" do |task, args|
152
-
153
- @files.each do |file|
154
- download = file_fetch(file['url'], file['sha1'])
155
- if download =~ /.tar.gz/
156
- prefix = download.gsub('.tar.gz', '').gsub('vendor/', '')
157
- untar(download) do |entry|
158
- if !file['files'].nil?
159
- next unless file['files'].include?(entry.full_name.gsub(prefix, ''))
160
- out = entry.full_name.split("/").last
161
- end
162
- File.join('vendor', out)
163
- end
164
- elsif download =~ /.gz/
165
- ungz(download)
166
- end
167
- end
168
-
169
- end