logstash-filter-xml 0.1.0 → 0.1.2

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
- NjBhYWFkYzM0NjM2ODNkNmQwYTg3YzRkNjc0ZmUzMDFhYjkzNTkzNg==
5
- data.tar.gz: !binary |-
6
- ZjM5NWZhMzczOTZkZTRmOTFiZmVjNDNhOWNiNDk2YjJjODc3Y2M3OQ==
2
+ SHA1:
3
+ metadata.gz: b7fd25d440b0df516cae7ba96eb400efdaa142eb
4
+ data.tar.gz: 02f3550e09fc68ecc383b59f0dbf4ead4c9a999a
7
5
  SHA512:
8
- metadata.gz: !binary |-
9
- ODNkOTFiNDVhODEyNWI5NzcwYmJiNWU3ZmNjYTJmNDRmMWZkMGY0ZjAwODg1
10
- ZDhhOGUzYTg5NmYxOTQ0ZjBjZTAzYzFiMDQ2ZjVmYmMwYTcyY2U1YmEzODE1
11
- Mzc4OTkxY2JiMGI1YmJiMDgzMzIyMDg2ZWU0ZjVjYTdmZTFkNWU=
12
- data.tar.gz: !binary |-
13
- MmJlM2M0MTRhNDEwODU1Y2I2OWE5ZGIxYWMxZGZkMTRkMDllNjhlNWJlYTE3
14
- NzQ4NmU0YTI5ZDkxMzY4NGJkZDgxODc4NTZmMGQ2ODkxMDdmMWU1YTE4N2Fj
15
- MGMxYmJhN2FmNGMyY2ZhOGZmOGQzMTFlMjUwYmVjMzFkMTEwM2M=
6
+ metadata.gz: 32b9892df7bd97edc06cc5165433ff7818894fb97dc8379797fc5c6ad2ef8fd030303e69eae940214cf64372712768a049d7a0f7186c0bc1d35c653c5c29f0b5
7
+ data.tar.gz: 4b9fffa4ac1b0839c0ec4f6c2bc1c81635624fc68595f6aa1d1df82a0379b6de9ff2266e556afcb097285c96a423e2b2d85392316c085e98eedde4b049fbfb63
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
@@ -4,3 +4,4 @@ task :default do
4
4
  system("rake -T")
5
5
  end
6
6
 
7
+ require "logstash/devutils/rake"
@@ -10,24 +10,24 @@ class LogStash::Filters::Xml < LogStash::Filters::Base
10
10
  milestone 1
11
11
 
12
12
  # Config for xml to hash is:
13
- #
13
+ # [source,ruby]
14
14
  # source => source_field
15
15
  #
16
- # For example, if you have the whole xml document in your @message field:
17
- #
16
+ # For example, if you have the whole xml document in your message field:
17
+ # [source,ruby]
18
18
  # filter {
19
19
  # xml {
20
20
  # source => "message"
21
21
  # }
22
22
  # }
23
23
  #
24
- # The above would parse the xml from the @message field
25
- config :source, :validate => :string
24
+ # The above would parse the xml from the message field
25
+ config :source, :validate => :string, :required => true
26
26
 
27
27
  # Define target for placing the data
28
28
  #
29
29
  # for example if you want the data to be put in the 'doc' field:
30
- #
30
+ # [source,ruby]
31
31
  # filter {
32
32
  # xml {
33
33
  # target => "doc"
@@ -35,15 +35,15 @@ class LogStash::Filters::Xml < LogStash::Filters::Base
35
35
  # }
36
36
  #
37
37
  # XML in the value of the source field will be expanded into a
38
- # datastructure in the "target" field.
39
- # Note: if the "target" field already exists, it will be overridden
38
+ # datastructure in the `target` field.
39
+ # Note: if the `target` field already exists, it will be overridden
40
40
  # Required
41
41
  config :target, :validate => :string
42
42
 
43
43
  # xpath will additionally select string values (.to_s on whatever is selected)
44
44
  # from parsed XML (using each source field defined using the method above)
45
45
  # and place those values in the destination fields. Configuration:
46
- #
46
+ # [source,ruby]
47
47
  # xpath => [ "xpath-syntax", "destination-field" ]
48
48
  #
49
49
  # Values returned by XPath parsring from xpath-synatx will be put in the
@@ -91,7 +91,7 @@ class LogStash::Filters::Xml < LogStash::Filters::Base
91
91
 
92
92
  if @xpath
93
93
  begin
94
- doc = Nokogiri::XML(value)
94
+ doc = Nokogiri::XML(value, nil, value.encoding.to_s)
95
95
  rescue => e
96
96
  event.tag("_xmlparsefailure")
97
97
  @logger.warn("Trouble parsing xml", :source => @source, :value => value,
@@ -1,13 +1,13 @@
1
1
  Gem::Specification.new do |s|
2
2
 
3
3
  s.name = 'logstash-filter-xml'
4
- s.version = '0.1.0'
4
+ s.version = '0.1.2'
5
5
  s.licenses = ['Apache License (2.0)']
6
6
  s.summary = "Takes a field that contains XML and expands it into an actual datastructure."
7
- s.description = "Takes a field that contains XML and expands it into an actual datastructure."
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,11 +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" => "filter" }
20
+ s.metadata = { "logstash_plugin" => "true", "logstash_group" => "filter" }
21
21
 
22
22
  # Gem dependencies
23
23
  s.add_runtime_dependency 'logstash', '>= 1.4.0', '< 2.0.0'
24
24
  s.add_runtime_dependency 'nokogiri'
25
+ s.add_runtime_dependency 'xml-simple'
25
26
 
27
+ s.add_development_dependency 'logstash-devutils'
26
28
  end
27
29
 
@@ -1,5 +1,5 @@
1
1
  # encoding: utf-8
2
- require "spec_helper"
2
+ require "logstash/devutils/rspec/spec_helper"
3
3
  require "logstash/filters/xml"
4
4
 
5
5
  describe LogStash::Filters::Xml do
metadata CHANGED
@@ -1,87 +1,114 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: logstash-filter-xml
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.1.0
4
+ version: 0.1.2
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-25 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: nokogiri
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'
45
+ prerelease: false
40
46
  type: :runtime
47
+ - !ruby/object:Gem::Dependency
48
+ name: xml-simple
49
+ version_requirements: !ruby/object:Gem::Requirement
50
+ requirements:
51
+ - - '>='
52
+ - !ruby/object:Gem::Version
53
+ version: '0'
54
+ requirement: !ruby/object:Gem::Requirement
55
+ requirements:
56
+ - - '>='
57
+ - !ruby/object:Gem::Version
58
+ version: '0'
41
59
  prerelease: false
60
+ type: :runtime
61
+ - !ruby/object:Gem::Dependency
62
+ name: logstash-devutils
42
63
  version_requirements: !ruby/object:Gem::Requirement
43
64
  requirements:
44
- - - ! '>='
65
+ - - '>='
45
66
  - !ruby/object:Gem::Version
46
67
  version: '0'
47
- description: Takes a field that contains XML and expands it into an actual datastructure.
48
- email: richard.pijnenburg@elasticsearch.com
68
+ requirement: !ruby/object:Gem::Requirement
69
+ requirements:
70
+ - - '>='
71
+ - !ruby/object:Gem::Version
72
+ version: '0'
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
49
77
  executables: []
50
78
  extensions: []
51
79
  extra_rdoc_files: []
52
80
  files:
53
81
  - .gitignore
54
82
  - Gemfile
83
+ - LICENSE
55
84
  - Rakefile
56
85
  - lib/logstash/filters/xml.rb
57
86
  - logstash-filter-xml.gemspec
58
- - rakelib/publish.rake
59
- - rakelib/vendor.rake
60
87
  - spec/filters/xml_spec.rb
61
- homepage: http://logstash.net/
88
+ homepage: http://www.elasticsearch.org/guide/en/logstash/current/index.html
62
89
  licenses:
63
90
  - Apache License (2.0)
64
91
  metadata:
65
92
  logstash_plugin: 'true'
66
- group: filter
67
- post_install_message:
93
+ logstash_group: filter
94
+ post_install_message:
68
95
  rdoc_options: []
69
96
  require_paths:
70
97
  - lib
71
98
  required_ruby_version: !ruby/object:Gem::Requirement
72
99
  requirements:
73
- - - ! '>='
100
+ - - '>='
74
101
  - !ruby/object:Gem::Version
75
102
  version: '0'
76
103
  required_rubygems_version: !ruby/object:Gem::Requirement
77
104
  requirements:
78
- - - ! '>='
105
+ - - '>='
79
106
  - !ruby/object:Gem::Version
80
107
  version: '0'
81
108
  requirements: []
82
- rubyforge_project:
83
- rubygems_version: 2.4.1
84
- signing_key:
109
+ rubyforge_project:
110
+ rubygems_version: 2.4.4
111
+ signing_key:
85
112
  specification_version: 4
86
113
  summary: Takes a field that contains XML and expands it into an actual datastructure.
87
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