logstash-input-sqlite 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
- YmQ0ZTFlMzE0ZWRmNTFkY2U2MjY3NGExNzcxMDBhMjZhZDE1NTllMg==
5
- data.tar.gz: !binary |-
6
- NmNmMWY4ZmQ3NDBjMzA1ZTI5ZDY2OTEyOTYzZDE1YWMwOWI0ODhhMg==
2
+ SHA1:
3
+ metadata.gz: 4afb6502ec6401e9811465ff1ee2d095cab71b5e
4
+ data.tar.gz: a3c1492e80aa484e81993ba43b6c29a1cde2ff8b
7
5
  SHA512:
8
- metadata.gz: !binary |-
9
- NmQyMGMyMDE2YzRiMzFhZmQ3Yzc3MGUwOGQyYjA1MThhM2VhNWM5MmM4NWRl
10
- YjNiNTMzM2E0MmIzMWIyNGJhNTFlNmQwZDZhNzA1MzY5ODRmZWIyNTIzZGNk
11
- Nzc2ZWFhZTg5YTUwZTRkYjJhODczZTEzOWI2NTdiZjNiMmNlOTY=
12
- data.tar.gz: !binary |-
13
- NDE3OTBjMzM3Y2U0OWJkZjM3MjFjZmRjYTUwOGE3ODY2NzU4Njc3Njg4MjVi
14
- YWE0MzI5Y2E4MzBhYjhlYjViN2VjMjIyNmY0NmVhZmIzZGM2ZjFkZDNkNzgy
15
- MzliYWVjMmE5YmE2M2I1MDliMWYxNGU2ZGQ0ZTRkNzNkY2FlNzA=
6
+ metadata.gz: 4be909091cd5d4557cdfe2f52a8f33477a9ec1354d16ed3281bc4d71ed70765fc820e4dc2da6dc9beceec940559e6519751660539bb52f1131264914dcb8ce74
7
+ data.tar.gz: 16c0e02403be292668349c3c88d64c357b21afebab5c6e7dfcb82fee8b074cdac50e011bd6d1370e3bcf48ca20dfc192e19ed5efb987a0510c3f227f3a546438
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"
@@ -7,15 +7,16 @@ require "socket"
7
7
  # Read rows from an sqlite database.
8
8
  #
9
9
  # This is most useful in cases where you are logging directly to a table.
10
- # Any tables being watched must have an 'id' column that is monotonically
10
+ # Any tables being watched must have an `id` column that is monotonically
11
11
  # increasing.
12
12
  #
13
13
  # All tables are read by default except:
14
- # * ones matching 'sqlite_%' - these are internal/adminstrative tables for sqlite
15
- # * 'since_table' - this is used by this plugin to track state.
16
- #
17
- # ## Example
18
14
  #
15
+ # * ones matching `sqlite_%` - these are internal/adminstrative tables for sqlite
16
+ # * `since_table` - this is used by this plugin to track state.
17
+ #
18
+ # Example
19
+ # [source,sql]
19
20
  # % sqlite /tmp/example.db
20
21
  # sqlite> CREATE TABLE weblogs (
21
22
  # id INTEGER PRIMARY KEY AUTOINCREMENT,
@@ -26,7 +27,7 @@ require "socket"
26
27
  # VALUES ("1.2.3.4", "/index.html", 200);
27
28
  #
28
29
  # Then with this logstash config:
29
- #
30
+ # [source,ruby]
30
31
  # input {
31
32
  # sqlite {
32
33
  # path => "/tmp/example.db"
@@ -40,7 +41,7 @@ require "socket"
40
41
  # }
41
42
  #
42
43
  # Sample output:
43
- #
44
+ # [source,ruby]
44
45
  # {
45
46
  # "@source" => "sqlite://sadness/tmp/x.db",
46
47
  # "@tags" => [],
@@ -67,7 +68,7 @@ class LogStash::Inputs::Sqlite < LogStash::Inputs::Base
67
68
  # By default all tables are followed.
68
69
  config :exclude_tables, :validate => :array, :default => []
69
70
 
70
- # How many rows to fetch at a time from each SELECT call.
71
+ # How many rows to fetch at a time from each `SELECT` call.
71
72
  config :batch, :validate => :number, :default => 5
72
73
 
73
74
  SINCE_TABLE = :since_table
@@ -1,13 +1,13 @@
1
1
  Gem::Specification.new do |s|
2
2
 
3
3
  s.name = 'logstash-input-sqlite'
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 rows from an sqlite database."
7
- s.description = "Read rows from an sqlite database."
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,7 +17,7 @@ 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'
@@ -25,5 +25,6 @@ Gem::Specification.new do |s|
25
25
  s.add_runtime_dependency 'sequel'
26
26
  s.add_runtime_dependency 'jdbc-sqlite3'
27
27
 
28
+ s.add_development_dependency 'logstash-devutils'
28
29
  end
29
30
 
@@ -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-sqlite
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: sequel
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: jdbc-sqlite3
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: jdbc-sqlite3
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: Read rows from an sqlite database.
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: []
@@ -70,33 +84,31 @@ files:
70
84
  - Rakefile
71
85
  - lib/logstash/inputs/sqlite.rb
72
86
  - logstash-input-sqlite.gemspec
73
- - rakelib/publish.rake
74
- - rakelib/vendor.rake
75
87
  - spec/inputs/sqlite_spec.rb
76
- homepage: http://logstash.net/
88
+ homepage: http://www.elasticsearch.org/guide/en/logstash/current/index.html
77
89
  licenses:
78
90
  - Apache License (2.0)
79
91
  metadata:
80
92
  logstash_plugin: 'true'
81
- group: input
82
- post_install_message:
93
+ logstash_group: input
94
+ post_install_message:
83
95
  rdoc_options: []
84
96
  require_paths:
85
97
  - lib
86
98
  required_ruby_version: !ruby/object:Gem::Requirement
87
99
  requirements:
88
- - - ! '>='
100
+ - - '>='
89
101
  - !ruby/object:Gem::Version
90
102
  version: '0'
91
103
  required_rubygems_version: !ruby/object:Gem::Requirement
92
104
  requirements:
93
- - - ! '>='
105
+ - - '>='
94
106
  - !ruby/object:Gem::Version
95
107
  version: '0'
96
108
  requirements: []
97
- rubyforge_project:
98
- rubygems_version: 2.4.1
99
- signing_key:
109
+ rubyforge_project:
110
+ rubygems_version: 2.2.2
111
+ signing_key:
100
112
  specification_version: 4
101
113
  summary: Read rows from an sqlite database.
102
114
  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