logstash-output-sqs 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
- NDJlY2U2NWQ5OTNlYmZkOGQyZTUxYmFjNzM4YmVjNDFlODIwMmExNw==
5
- data.tar.gz: !binary |-
6
- MDNiY2NlNWM0N2ZlNDU4NTZmMDY3OWI2MWRkYzg1YzQzZTNlNjk3OA==
2
+ SHA1:
3
+ metadata.gz: eb24e6e28ffd96fa51ce85aee0f8da8e4117f18e
4
+ data.tar.gz: 03156c260961b32112cb9c5c470829908f4306a2
7
5
  SHA512:
8
- metadata.gz: !binary |-
9
- YzgzZjBjN2M5ZjM1ZjEyNzdkNTQwNTcxN2QwYzE4YzhlZmQ3NDhiODRiOWVk
10
- ZTNlN2MyYzNlNDRiZjdmNmU0NzZhM2VhMWI0YTNlNjg2ZGUwMmNhM2MxYjNh
11
- MmI1M2I3NDU3Nzk3YzQzYzBiMDA5NzFiY2NkNzBjMjk1Y2FmMjM=
12
- data.tar.gz: !binary |-
13
- YzNhZTY4OWRhZjIwOTM5OWZkNzU4N2UxOTgzMGFmZTE4M2VhMGU1YjZkYjZl
14
- MmVkMTVmZjhkZjA3MGFlZTg0OWFlYjFiN2ZmMDAzNmNjZjUzYjBjYTI2MmY3
15
- ZDk4ZTM0ZjZlOGE1MTBjNzY0MjM1ZjQzYTU1Nzc5MmVhNjMwZGY=
6
+ metadata.gz: c51984e614c04786eb2a8974130f75b7648331c9ab2991ff31b9c7d2b6e0cad5e3ffab98ecf920bd046992b7d309a7a77f198902701d37a823e334d526419a91
7
+ data.tar.gz: 75cba9124bdda25121c7a5081a12ccd170c13ac9a225a9aba4088275e3d0a7f1267fdbe89fcae295d12ee8f46d38a203559318ae2d9637abf3b18011245acc69
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"
@@ -33,7 +33,7 @@ require "digest/sha2"
33
33
  #
34
34
  # Typically, you should setup an IAM policy, create a user and apply the IAM policy to the user.
35
35
  # A sample policy is as follows:
36
- #
36
+ # [source,ruby]
37
37
  # {
38
38
  # "Statement": [
39
39
  # {
@@ -68,14 +68,14 @@ class LogStash::Outputs::SQS < LogStash::Outputs::Base
68
68
  # Name of SQS queue to push messages into. Note that this is just the name of the queue, not the URL or ARN.
69
69
  config :queue, :validate => :string, :required => true
70
70
 
71
- # Set to true if you want send messages to SQS in batches with batch_send
71
+ # Set to true if you want send messages to SQS in batches with `batch_send`
72
72
  # from the amazon sdk
73
73
  config :batch, :validate => :boolean, :default => true
74
74
 
75
- # If batch is set to true, the number of events we queue up for a batch_send.
75
+ # If `batch` is set to true, the number of events we queue up for a `batch_send`.
76
76
  config :batch_events, :validate => :number, :default => 10
77
77
 
78
- # If batch is set to true, the maximum amount of time between batch_send commands when there are pending events to flush.
78
+ # If `batch` is set to true, the maximum amount of time between `batch_send` commands when there are pending events to flush.
79
79
  config :batch_timeout, :validate => :number, :default => 5
80
80
 
81
81
  public
@@ -1,13 +1,13 @@
1
1
  Gem::Specification.new do |s|
2
2
 
3
3
  s.name = 'logstash-output-sqs'
4
- s.version = '0.1.0'
4
+ s.version = '0.1.1'
5
5
  s.licenses = ['Apache License (2.0)']
6
6
  s.summary = "Push events to an Amazon Web Services Simple Queue Service (SQS) queue."
7
- s.description = "Push events to an Amazon Web Services Simple Queue Service (SQS) queue."
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,13 +17,15 @@ 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" => "output" }
20
+ s.metadata = { "logstash_plugin" => "true", "logstash_group" => "output" }
21
21
 
22
22
  # Gem dependencies
23
23
  s.add_runtime_dependency 'logstash', '>= 1.4.0', '< 2.0.0'
24
+ s.add_runtime_dependency 'logstash-mixin-aws'
24
25
 
25
26
  s.add_runtime_dependency 'aws-sdk'
26
27
  s.add_runtime_dependency 'stud'
27
28
 
29
+ s.add_development_dependency 'logstash-devutils'
28
30
  end
29
31
 
@@ -1 +1,5 @@
1
- require 'spec_helper'
1
+ # encoding: utf-8
2
+ require "logstash/devutils/rspec/spec_helper"
3
+ require 'logstash/outputs/sqs'
4
+
5
+
metadata CHANGED
@@ -1,65 +1,93 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: logstash-output-sqs
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-06 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
- name: logstash
15
14
  requirement: !ruby/object:Gem::Requirement
16
15
  requirements:
17
- - - ! '>='
16
+ - - '>='
18
17
  - !ruby/object:Gem::Version
19
18
  version: 1.4.0
20
19
  - - <
21
20
  - !ruby/object:Gem::Version
22
21
  version: 2.0.0
23
- type: :runtime
22
+ name: logstash
24
23
  prerelease: false
24
+ type: :runtime
25
25
  version_requirements: !ruby/object:Gem::Requirement
26
26
  requirements:
27
- - - ! '>='
27
+ - - '>='
28
28
  - !ruby/object:Gem::Version
29
29
  version: 1.4.0
30
30
  - - <
31
31
  - !ruby/object:Gem::Version
32
32
  version: 2.0.0
33
33
  - !ruby/object:Gem::Dependency
34
- name: aws-sdk
35
34
  requirement: !ruby/object:Gem::Requirement
36
35
  requirements:
37
- - - ! '>='
36
+ - - '>='
38
37
  - !ruby/object:Gem::Version
39
38
  version: '0'
39
+ name: logstash-mixin-aws
40
+ prerelease: false
40
41
  type: :runtime
42
+ version_requirements: !ruby/object:Gem::Requirement
43
+ requirements:
44
+ - - '>='
45
+ - !ruby/object:Gem::Version
46
+ version: '0'
47
+ - !ruby/object:Gem::Dependency
48
+ requirement: !ruby/object:Gem::Requirement
49
+ requirements:
50
+ - - '>='
51
+ - !ruby/object:Gem::Version
52
+ version: '0'
53
+ name: aws-sdk
41
54
  prerelease: false
55
+ type: :runtime
42
56
  version_requirements: !ruby/object:Gem::Requirement
43
57
  requirements:
44
- - - ! '>='
58
+ - - '>='
45
59
  - !ruby/object:Gem::Version
46
60
  version: '0'
47
61
  - !ruby/object:Gem::Dependency
48
- name: stud
49
62
  requirement: !ruby/object:Gem::Requirement
50
63
  requirements:
51
- - - ! '>='
64
+ - - '>='
52
65
  - !ruby/object:Gem::Version
53
66
  version: '0'
67
+ name: stud
68
+ prerelease: false
54
69
  type: :runtime
70
+ version_requirements: !ruby/object:Gem::Requirement
71
+ requirements:
72
+ - - '>='
73
+ - !ruby/object:Gem::Version
74
+ version: '0'
75
+ - !ruby/object:Gem::Dependency
76
+ requirement: !ruby/object:Gem::Requirement
77
+ requirements:
78
+ - - '>='
79
+ - !ruby/object:Gem::Version
80
+ version: '0'
81
+ name: logstash-devutils
55
82
  prerelease: false
83
+ type: :development
56
84
  version_requirements: !ruby/object:Gem::Requirement
57
85
  requirements:
58
- - - ! '>='
86
+ - - '>='
59
87
  - !ruby/object:Gem::Version
60
88
  version: '0'
61
- description: Push events to an Amazon Web Services Simple Queue Service (SQS) queue.
62
- email: richard.pijnenburg@elasticsearch.com
89
+ 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
90
+ email: info@elasticsearch.com
63
91
  executables: []
64
92
  extensions: []
65
93
  extra_rdoc_files: []
@@ -70,33 +98,31 @@ files:
70
98
  - Rakefile
71
99
  - lib/logstash/outputs/sqs.rb
72
100
  - logstash-output-sqs.gemspec
73
- - rakelib/publish.rake
74
- - rakelib/vendor.rake
75
101
  - spec/outputs/sqs_spec.rb
76
- homepage: http://logstash.net/
102
+ homepage: http://www.elasticsearch.org/guide/en/logstash/current/index.html
77
103
  licenses:
78
104
  - Apache License (2.0)
79
105
  metadata:
80
106
  logstash_plugin: 'true'
81
- group: output
82
- post_install_message:
107
+ logstash_group: output
108
+ post_install_message:
83
109
  rdoc_options: []
84
110
  require_paths:
85
111
  - lib
86
112
  required_ruby_version: !ruby/object:Gem::Requirement
87
113
  requirements:
88
- - - ! '>='
114
+ - - '>='
89
115
  - !ruby/object:Gem::Version
90
116
  version: '0'
91
117
  required_rubygems_version: !ruby/object:Gem::Requirement
92
118
  requirements:
93
- - - ! '>='
119
+ - - '>='
94
120
  - !ruby/object:Gem::Version
95
121
  version: '0'
96
122
  requirements: []
97
- rubyforge_project:
98
- rubygems_version: 2.4.1
99
- signing_key:
123
+ rubyforge_project:
124
+ rubygems_version: 2.1.9
125
+ signing_key:
100
126
  specification_version: 4
101
127
  summary: Push events to an Amazon Web Services Simple Queue Service (SQS) queue.
102
128
  test_files:
@@ -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
-
@@ -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