fluent-plugin-explode_filter 0.1.0

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 ADDED
@@ -0,0 +1,7 @@
1
+ ---
2
+ SHA1:
3
+ metadata.gz: e2fa5a83c06d9f2009de1b493f07315fee44c8fc
4
+ data.tar.gz: 400de57195fd213c16052339b84ae6d4be72c7ef
5
+ SHA512:
6
+ metadata.gz: c46fce4f907c0b492fae8721c6e09c448b0183fbd6be2d321dd3e88a756b02d49be546328e17319cee688ba85ad6314aa7abe95222902365f60f63d5de7fc309
7
+ data.tar.gz: e4e6bdf37f936658347e33b1497a29831071308f7a2fd6f816b0f8b2f6a59d08ea6951af67bad5c8e6c4dead22bb390f90d690df6fc6ea9f4bf3ef21cabec7ab
data/.gitignore ADDED
@@ -0,0 +1,10 @@
1
+ /.bundle/
2
+ /.yardoc
3
+ /Gemfile.lock
4
+ /_yardoc/
5
+ /coverage/
6
+ /doc/
7
+ /pkg/
8
+ /spec/reports/
9
+ /tmp/
10
+ *.gem
data/CHANGELOG.md ADDED
@@ -0,0 +1,5 @@
1
+ # Changelog
2
+
3
+ v0.1.0
4
+ ---------------
5
+ * Initial release
data/Gemfile ADDED
@@ -0,0 +1,4 @@
1
+ source 'https://rubygems.org'
2
+
3
+ # Specify your gem's dependencies in fluent-plugin-explode_filter.gemspec
4
+ gemspec
data/LICENSE.txt ADDED
@@ -0,0 +1,11 @@
1
+ Licensed under the Apache License, Version 2.0 (the "License");
2
+ you may not use this file except in compliance with the License.
3
+ You may obtain a copy of the License at
4
+
5
+ http://www.apache.org/licenses/LICENSE-2.0
6
+
7
+ Unless required by applicable law or agreed to in writing, software
8
+ distributed under the License is distributed on an "AS IS" BASIS,
9
+ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
10
+ See the License for the specific language governing permissions and
11
+ limitations under the License.
data/README.md ADDED
@@ -0,0 +1,44 @@
1
+ # Fluent::Plugin::ExplodeFilter
2
+
3
+ This gem provides the explode Fluentd filter which is used to convert period separated fields to nested hashes.
4
+
5
+ The current use case being to expand Gelf formatted messages as well as to ensure compatibility with newer elasticsearch versions.
6
+
7
+ ## Requirements
8
+
9
+ * Fluentd v0.12+
10
+ * fluent-plugin-mutate_filter
11
+
12
+ ## Installation
13
+
14
+ ```bash
15
+ gem install fluent-plugin-explode_filter
16
+ ```
17
+
18
+ ## Configuration Options
19
+
20
+ ```
21
+ <filter *>
22
+ @type explode
23
+ </filter
24
+ ```
25
+
26
+ ## Example
27
+
28
+ ```json
29
+ {
30
+ "short_message": "a short message",
31
+ "context.level": 5,
32
+ "context.revision": "sha256"
33
+ }
34
+ ```
35
+
36
+ ```json
37
+ {
38
+ "short_message": "a short message",
39
+ "context": {
40
+ "level": 5,
41
+ "revision": "sha256"
42
+ }
43
+ }
44
+ ```
data/Rakefile ADDED
@@ -0,0 +1,2 @@
1
+ require "bundler/gem_tasks"
2
+ task :default => :spec
data/bin/console ADDED
@@ -0,0 +1,14 @@
1
+ #!/usr/bin/env ruby
2
+
3
+ require "bundler/setup"
4
+ require "fluent/plugin/explode_filter"
5
+
6
+ # You can add fixtures and/or initialization code here to make experimenting
7
+ # with your gem easier. You can also use a different console, if you like.
8
+
9
+ # (If you use this, don't forget to add pry to your Gemfile!)
10
+ # require "pry"
11
+ # Pry.start
12
+
13
+ require "irb"
14
+ IRB.start
data/bin/setup ADDED
@@ -0,0 +1,8 @@
1
+ #!/usr/bin/env bash
2
+ set -euo pipefail
3
+ IFS=$'\n\t'
4
+ set -vx
5
+
6
+ bundle install
7
+
8
+ # Do any other automated setup that you need to do here
@@ -0,0 +1,22 @@
1
+ # coding: utf-8
2
+ Gem::Specification.new do |spec|
3
+ spec.name = "fluent-plugin-explode_filter"
4
+ spec.version = "0.1.0"
5
+ spec.authors = ["Jonathan Serafini"]
6
+ spec.email = ["jonathan@serafini.ca"]
7
+
8
+ spec.summary = %{A fluentd filter plugin that will split period separated fields to nested hashes.}
9
+ spec.description = spec.summary
10
+ spec.homepage = "https://github.com/JonathanSerafini/fluent-plugin-explode_filter"
11
+ spec.license = "apache2"
12
+
13
+ spec.files = `git ls-files -z`.split("\x0").reject { |f| f.match(%r{^(test|spec|features)/}) }
14
+ spec.executables = []
15
+ spec.require_paths = ["lib"]
16
+
17
+ spec.add_development_dependency "bundler", "~> 1.11"
18
+ spec.add_development_dependency "rake", "~> 10.0"
19
+
20
+ spec.add_runtime_dependency "fluentd", [">= 0.12.0", "< 0.15.0"]
21
+ spec.add_runtime_dependency "fluent-plugin-mutate_filter", "<= 1.1.0"
22
+ end
@@ -0,0 +1,19 @@
1
+ require 'fluent/filter'
2
+ require 'fluent/plugin_mixin/mutate_event'
3
+
4
+ module Fluent
5
+ class ExplodeFilter < Filter
6
+ Fluent::Plugin.register_filter('explode', self)
7
+
8
+ def filter(tag, time, record)
9
+ event = Fluent::PluginMixin::MutateEvent.new(record, false)
10
+ event_data = Fluent::PluginMixin::MutateEvent.new({}, true)
11
+
12
+ event.keys.each do |key|
13
+ event_data.set(key, event.get(key))
14
+ end
15
+
16
+ event_data.to_record
17
+ end
18
+ end
19
+ end
metadata ADDED
@@ -0,0 +1,118 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: fluent-plugin-explode_filter
3
+ version: !ruby/object:Gem::Version
4
+ version: 0.1.0
5
+ platform: ruby
6
+ authors:
7
+ - Jonathan Serafini
8
+ autorequire:
9
+ bindir: bin
10
+ cert_chain: []
11
+ date: 2016-06-16 00:00:00.000000000 Z
12
+ dependencies:
13
+ - !ruby/object:Gem::Dependency
14
+ name: bundler
15
+ requirement: !ruby/object:Gem::Requirement
16
+ requirements:
17
+ - - "~>"
18
+ - !ruby/object:Gem::Version
19
+ version: '1.11'
20
+ type: :development
21
+ prerelease: false
22
+ version_requirements: !ruby/object:Gem::Requirement
23
+ requirements:
24
+ - - "~>"
25
+ - !ruby/object:Gem::Version
26
+ version: '1.11'
27
+ - !ruby/object:Gem::Dependency
28
+ name: rake
29
+ requirement: !ruby/object:Gem::Requirement
30
+ requirements:
31
+ - - "~>"
32
+ - !ruby/object:Gem::Version
33
+ version: '10.0'
34
+ type: :development
35
+ prerelease: false
36
+ version_requirements: !ruby/object:Gem::Requirement
37
+ requirements:
38
+ - - "~>"
39
+ - !ruby/object:Gem::Version
40
+ version: '10.0'
41
+ - !ruby/object:Gem::Dependency
42
+ name: fluentd
43
+ requirement: !ruby/object:Gem::Requirement
44
+ requirements:
45
+ - - ">="
46
+ - !ruby/object:Gem::Version
47
+ version: 0.12.0
48
+ - - "<"
49
+ - !ruby/object:Gem::Version
50
+ version: 0.15.0
51
+ type: :runtime
52
+ prerelease: false
53
+ version_requirements: !ruby/object:Gem::Requirement
54
+ requirements:
55
+ - - ">="
56
+ - !ruby/object:Gem::Version
57
+ version: 0.12.0
58
+ - - "<"
59
+ - !ruby/object:Gem::Version
60
+ version: 0.15.0
61
+ - !ruby/object:Gem::Dependency
62
+ name: fluent-plugin-mutate_filter
63
+ requirement: !ruby/object:Gem::Requirement
64
+ requirements:
65
+ - - "<="
66
+ - !ruby/object:Gem::Version
67
+ version: 1.1.0
68
+ type: :runtime
69
+ prerelease: false
70
+ version_requirements: !ruby/object:Gem::Requirement
71
+ requirements:
72
+ - - "<="
73
+ - !ruby/object:Gem::Version
74
+ version: 1.1.0
75
+ description: A fluentd filter plugin that will split period separated fields to nested
76
+ hashes.
77
+ email:
78
+ - jonathan@serafini.ca
79
+ executables: []
80
+ extensions: []
81
+ extra_rdoc_files: []
82
+ files:
83
+ - ".gitignore"
84
+ - CHANGELOG.md
85
+ - Gemfile
86
+ - LICENSE.txt
87
+ - README.md
88
+ - Rakefile
89
+ - bin/console
90
+ - bin/setup
91
+ - fluent-plugin-explode_filter.gemspec
92
+ - lib/fluent/plugin/filter_explode.rb
93
+ homepage: https://github.com/JonathanSerafini/fluent-plugin-explode_filter
94
+ licenses:
95
+ - apache2
96
+ metadata: {}
97
+ post_install_message:
98
+ rdoc_options: []
99
+ require_paths:
100
+ - lib
101
+ required_ruby_version: !ruby/object:Gem::Requirement
102
+ requirements:
103
+ - - ">="
104
+ - !ruby/object:Gem::Version
105
+ version: '0'
106
+ required_rubygems_version: !ruby/object:Gem::Requirement
107
+ requirements:
108
+ - - ">="
109
+ - !ruby/object:Gem::Version
110
+ version: '0'
111
+ requirements: []
112
+ rubyforge_project:
113
+ rubygems_version: 2.2.3
114
+ signing_key:
115
+ specification_version: 4
116
+ summary: A fluentd filter plugin that will split period separated fields to nested
117
+ hashes.
118
+ test_files: []