logstash-codec-collectd 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
- MDA5OTAxYjlhNjRhZGNkZTU2YzA4NDk4OTVmMjIxN2NlMmM1MzYyMA==
5
- data.tar.gz: !binary |-
6
- ZTk0NzIyYWFmNTM5Y2I4OTJmNzQyOTE0ZTg5N2ZhY2RlMDFkOGIzYg==
2
+ SHA1:
3
+ metadata.gz: b4e60562ff9d570e40a3f6cf758eb0a3a2fe5018
4
+ data.tar.gz: 302a157f4baa7d20848bfdd201c1d54d6743c859
7
5
  SHA512:
8
- metadata.gz: !binary |-
9
- ZDkxYTgxODI4NWMxZTRkYWNjN2ZlMzU2ZTNhYTU4ZDc1ZTZmNTQyZTA0YmVh
10
- NDJmNzU1ZjUzMTllOGM1ZDU5Nzg3MmI5ZDAzYzk3MmYyYTQyNzUwNTYzNGYx
11
- NmZkOWE1YTdkMGZlZTMzOWY0ZWMwOWI5OTZiZWRmOTMxMjk3ZjQ=
12
- data.tar.gz: !binary |-
13
- ZmViMDg2NjA1Njc0Y2RmYTgyYjM5MTQ4ODQ1NmU0ZTMzMzU2ZTJjMTJiODE0
14
- OTAyNzk5Y2MzOTU2YjEwN2YzYmFiMTlhYjQwYWE3YTlkYTc1Y2EzNjdiOTEy
15
- NjA5OTJjYTE0OTRhYjY4ZmRhZGU0MjJmYTcyZTczNDA3ZTBlOTA=
6
+ metadata.gz: 8d664c539f7bbb81d121d5654ab5ca584bfc8fe6211cad8c3b62601df2a91c4cbca98de8e1f3dbe452b14bf79a49378f3d893a6f46ce527e689aad61693fecbb
7
+ data.tar.gz: 53fcc5e548d4db964c86791c0c9823b09e456d8a52d28b4442c2ec1b9fbe9ddc6d619a6618966d7e16601158c6a9d283a036d3ad3440156458dd6f43f6cd4df5
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/LICENSE ADDED
@@ -0,0 +1,13 @@
1
+ Copyright (c) 2012-2014 Elasticsearch <http://www.elasticsearch.org>
2
+
3
+ Licensed under the Apache License, Version 2.0 (the "License");
4
+ you may not use this file except in compliance with the License.
5
+ You may obtain a copy of the License at
6
+
7
+ http://www.apache.org/licenses/LICENSE-2.0
8
+
9
+ Unless required by applicable law or agreed to in writing, software
10
+ distributed under the License is distributed on an "AS IS" BASIS,
11
+ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12
+ See the License for the specific language governing permissions and
13
+ limitations under the License.
data/Rakefile CHANGED
@@ -6,3 +6,4 @@ task :default do
6
6
  system("rake -T")
7
7
  end
8
8
 
9
+ require "logstash/devutils/rake"
@@ -6,10 +6,16 @@ require "logstash/errors"
6
6
  require "tempfile"
7
7
  require "time"
8
8
 
9
- # Read events from the connectd binary protocol over the network via udp.
9
+ class ProtocolError < LogStash::Error; end
10
+ class HeaderError < LogStash::Error; end
11
+ class EncryptionError < LogStash::Error; end
12
+ class NaNError < LogStash::Error; end
13
+
14
+ # Read events from the collectd binary protocol over the network via udp.
10
15
  # See https://collectd.org/wiki/index.php/Binary_protocol
11
16
  #
12
17
  # Configuration in your Logstash configuration file can be as simple as:
18
+ # [source,ruby]
13
19
  # input {
14
20
  # udp {
15
21
  # port => 28526
@@ -18,8 +24,8 @@ require "time"
18
24
  # }
19
25
  # }
20
26
  #
21
- # A sample collectd.conf to send to Logstash might be:
22
- #
27
+ # A sample `collectd.conf` to send to Logstash might be:
28
+ # [source,xml]
23
29
  # Hostname "host.example.com"
24
30
  # LoadPlugin interface
25
31
  # LoadPlugin load
@@ -34,14 +40,8 @@ require "time"
34
40
  # </Server>
35
41
  # </Plugin>
36
42
  #
37
- # Be sure to replace "10.0.0.1" with the IP of your Logstash instance.
43
+ # Be sure to replace `10.0.0.1` with the IP of your Logstash instance.
38
44
  #
39
-
40
- class ProtocolError < LogStash::Error; end
41
- class HeaderError < LogStash::Error; end
42
- class EncryptionError < LogStash::Error; end
43
- class NaNError < LogStash::Error; end
44
-
45
45
  class LogStash::Codecs::Collectd < LogStash::Codecs::Base
46
46
  config_name "collectd"
47
47
  milestone 1
@@ -106,37 +106,38 @@ class LogStash::Codecs::Collectd < LogStash::Codecs::Base
106
106
  SECURITY_SIGN = "Sign"
107
107
  SECURITY_ENCR = "Encrypt"
108
108
 
109
- # File path(s) to collectd types.db to use.
109
+ # File path(s) to collectd `types.db` to use.
110
110
  # The last matching pattern wins if you have identical pattern names in multiple files.
111
- # If no types.db is provided the included types.db will be used (currently 5.4.0).
111
+ # If no types.db is provided the included `types.db` will be used (currently 5.4.0).
112
112
  config :typesdb, :validate => :array
113
113
 
114
- # Prune interval records. Defaults to true.
114
+ # Prune interval records. Defaults to `true`.
115
115
  config :prune_intervals, :validate => :boolean, :default => true
116
116
 
117
- # Security Level. Default is "None". This setting mirrors the setting from the
118
- # collectd [Network plugin](https://collectd.org/wiki/index.php/Plugin:Network)
117
+ # Security Level. Default is `None`. This setting mirrors the setting from the
118
+ # collectd https://collectd.org/wiki/index.php/Plugin:Network[Network plugin]
119
119
  config :security_level, :validate => [SECURITY_NONE, SECURITY_SIGN, SECURITY_ENCR],
120
120
  :default => "None"
121
121
 
122
- # What to do when a value in the event is NaN (Not a Number)
123
- # - change_value (default): Change the NaN to the value of the nan_value option and add nan_tag as a tag
124
- # - warn: Change the NaN to the value of the nan_value option, print a warning to the log and add nan_tag as a tag
125
- # - drop: Drop the event containing the NaN (this only drops the single event, not the whole packet)
122
+ # What to do when a value in the event is `NaN` (Not a Number)
123
+ #
124
+ # - change_value (default): Change the `NaN` to the value of the nan_value option and add `nan_tag` as a tag
125
+ # - warn: Change the `NaN` to the value of the nan_value option, print a warning to the log and add `nan_tag` as a tag
126
+ # - drop: Drop the event containing the `NaN` (this only drops the single event, not the whole packet)
126
127
  config :nan_handling, :validate => ['change_value','warn','drop'], :default => 'change_value'
127
128
 
128
- # Only relevant when nan_handeling is set to 'change_value'
129
+ # Only relevant when `nan_handeling` is set to `change_value`
129
130
  # Change NaN to this configured value
130
131
  config :nan_value, :validate => :number, :default => 0
131
132
 
132
- # The tag to add to the event if a NaN value was found
133
+ # The tag to add to the event if a `NaN` value was found
133
134
  # Set this to an empty string ('') if you don't want to tag
134
135
  config :nan_tag, :validate => :string, :default => '_collectdNaN'
135
136
 
136
137
  # Path to the authentication file. This file should have the same format as
137
- # the [AuthFile](http://collectd.org/documentation/manpages/collectd.conf.5.shtml#authfile_filename)
138
- # in collectd. You only need to set this option if the security_level is set to
139
- # "Sign" or "Encrypt"
138
+ # the http://collectd.org/documentation/manpages/collectd.conf.5.shtml#authfile_filename[AuthFile]
139
+ # in collectd. You only need to set this option if the `security_level` is set to
140
+ # `Sign` or `Encrypt`
140
141
  config :authfile, :validate => :string
141
142
 
142
143
  public
@@ -1,13 +1,13 @@
1
1
  Gem::Specification.new do |s|
2
2
 
3
3
  s.name = 'logstash-codec-collectd'
4
- s.version = '0.1.0'
4
+ s.version = '0.1.1'
5
5
  s.licenses = ['Apache License (2.0)']
6
6
  s.summary = "Read events from the connectd binary protocol"
7
- s.description = "Read events from the connectd binary protocol"
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
9
  s.email = 'richard.pijnenburg@elasticsearch.com'
10
- s.homepage = "http://logstash.net/"
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,10 +17,11 @@ 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" => "codec" }
20
+ s.metadata = { "logstash_plugin" => "true", "logstash_group" => "codec" }
21
21
 
22
22
  # Gem dependencies
23
23
  s.add_runtime_dependency 'logstash', '>= 1.4.0', '< 2.0.0'
24
24
 
25
+ s.add_development_dependency 'logstash-devutils'
25
26
  end
26
27
 
@@ -1,3 +1,4 @@
1
+ require "logstash/devutils/rspec/spec_helper"
1
2
  require "logstash/codecs/collectd"
2
3
  require "logstash/event"
3
4
  require "insist"
metadata CHANGED
@@ -1,36 +1,50 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: logstash-codec-collectd
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-10-30 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
33
- description: Read events from the connectd binary protocol
31
+ prerelease: false
32
+ type: :runtime
33
+ - !ruby/object:Gem::Dependency
34
+ name: logstash-devutils
35
+ version_requirements: !ruby/object:Gem::Requirement
36
+ requirements:
37
+ - - '>='
38
+ - !ruby/object:Gem::Version
39
+ version: '0'
40
+ requirement: !ruby/object:Gem::Requirement
41
+ requirements:
42
+ - - '>='
43
+ - !ruby/object:Gem::Version
44
+ version: '0'
45
+ prerelease: false
46
+ type: :development
47
+ 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
34
48
  email: richard.pijnenburg@elasticsearch.com
35
49
  executables: []
36
50
  extensions: []
@@ -38,38 +52,37 @@ extra_rdoc_files: []
38
52
  files:
39
53
  - .gitignore
40
54
  - Gemfile
55
+ - LICENSE
41
56
  - Rakefile
42
57
  - lib/logstash/codecs/collectd.rb
43
58
  - logstash-codec-collectd.gemspec
44
- - rakelib/publish.rake
45
- - rakelib/vendor.rake
46
- - spec/codecs/collectd.rb
59
+ - spec/codecs/collectd_spec.rb
47
60
  - vendor/types.db
48
- homepage: http://logstash.net/
61
+ homepage: http://www.elasticsearch.org/guide/en/logstash/current/index.html
49
62
  licenses:
50
63
  - Apache License (2.0)
51
64
  metadata:
52
65
  logstash_plugin: 'true'
53
- group: codec
54
- post_install_message:
66
+ logstash_group: codec
67
+ post_install_message:
55
68
  rdoc_options: []
56
69
  require_paths:
57
70
  - lib
58
71
  required_ruby_version: !ruby/object:Gem::Requirement
59
72
  requirements:
60
- - - ! '>='
73
+ - - '>='
61
74
  - !ruby/object:Gem::Version
62
75
  version: '0'
63
76
  required_rubygems_version: !ruby/object:Gem::Requirement
64
77
  requirements:
65
- - - ! '>='
78
+ - - '>='
66
79
  - !ruby/object:Gem::Version
67
80
  version: '0'
68
81
  requirements: []
69
- rubyforge_project:
70
- rubygems_version: 2.4.1
71
- signing_key:
82
+ rubyforge_project:
83
+ rubygems_version: 2.4.4
84
+ signing_key:
72
85
  specification_version: 4
73
86
  summary: Read events from the connectd binary protocol
74
87
  test_files:
75
- - spec/codecs/collectd.rb
88
+ - spec/codecs/collectd_spec.rb
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 response.code != "200"
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