fluent-plugin-flatten 0.0.1

Sign up to get free protection for your applications and to get access to all the features.
@@ -0,0 +1,18 @@
1
+ *.gem
2
+ *.rbc
3
+ .bundle
4
+ .config
5
+ .yardoc
6
+ Gemfile.lock
7
+ InstalledFiles
8
+ _yardoc
9
+ coverage
10
+ doc/
11
+ lib/bundler/man
12
+ pkg
13
+ rdoc
14
+ spec/reports
15
+ test/tmp
16
+ test/version_tmp
17
+ tmp
18
+ vendor/bundle
data/Gemfile ADDED
@@ -0,0 +1,2 @@
1
+ source 'https://rubygems.org'
2
+ gemspec
data/LICENSE ADDED
@@ -0,0 +1,2 @@
1
+ Copyright (c) 2012 Kentaro Kuribayashi
2
+ Apache License, Version 2.0
@@ -0,0 +1,81 @@
1
+ # fluent-plugin-flatten
2
+
3
+ ## Component
4
+
5
+ ### FlattenOutput
6
+
7
+ Fluentd output plugin to flatten JSON-formatted string values in records to top level key/value-s.
8
+
9
+ ## Synopsis
10
+
11
+ When you have a config as below:
12
+
13
+ ```
14
+ <match test.**>
15
+ type flatten
16
+ key foo
17
+ </match>
18
+ ```
19
+
20
+ And you feed such a value into fluentd:
21
+
22
+ ```
23
+ {
24
+ "foo" => '{"bar" : {"qux" : "quux", "hoe" : "poe" }, "baz" : "bazz" }',
25
+ "hoge" => "fuga"
26
+ }
27
+ ```
28
+
29
+ Then you'll get:
30
+
31
+ ```
32
+ {
33
+ "foo" => '{"bar" : {"qux" : "quux", "hoe" : "poe" }, "baz" : "bazz" }',
34
+ "hoge" => "fuga",
35
+
36
+ "foo.bar.qux" => "quux",
37
+ "foo.bar.hoe" => "poe",
38
+ "foo.baz" => "bazz"
39
+ }
40
+ ```
41
+
42
+ That is, JSON-formatted string in the value of the key `foo` is flattened and now put into the top level of the hash.
43
+
44
+ ## Configuration
45
+
46
+ ### key
47
+
48
+ The `key` is used to point a key whose value contains JSON-formatted
49
+ string.
50
+
51
+ ## Installation
52
+
53
+ Add this line to your application's Gemfile:
54
+
55
+ gem 'fluent-plugin-flatten'
56
+
57
+ And then execute:
58
+
59
+ $ bundle
60
+
61
+ Or install it yourself as:
62
+
63
+ $ gem install fluent-plugin-flatten
64
+
65
+ ## Contributing
66
+
67
+ 1. Fork it
68
+ 2. Create your feature branch (`git checkout -b my-new-feature`)
69
+ 3. Commit your changes (`git commit -am 'Added some feature'`)
70
+ 4. Push to the branch (`git push origin my-new-feature`)
71
+ 5. Create new Pull Request
72
+
73
+ ## Copyright
74
+
75
+ ### Copyright
76
+
77
+ Copyright (c) 2012- Kentaro Kuribayashi (@kentaro)
78
+
79
+ ### License
80
+
81
+ Apache License, Version 2.0
@@ -0,0 +1,9 @@
1
+ #!/usr/bin/env rake
2
+ require "bundler/gem_tasks"
3
+ require 'rake/testtask'
4
+
5
+ Rake::TestTask.new(:test) do |test|
6
+ test.libs << 'lib' << 'test'
7
+ test.pattern = 'test/**/test_*.rb'
8
+ test.verbose = true
9
+ end
@@ -0,0 +1,18 @@
1
+ Gem::Specification.new do |gem|
2
+ gem.name = 'fluent-plugin-flatten'
3
+ gem.version = '0.0.1'
4
+ gem.authors = ['Kentaro Kuribayashi']
5
+ gem.email = ['kentarok@gmail.com']
6
+ gem.homepage = 'http://github.com/kentaro/fluent-plugin-flatten'
7
+ gem.description = %q{Fluentd plugin to flatten JSON-formatted string values to top level key/value-s.}
8
+ gem.summary = %q{Fluentd plugin to flatten JSON-formatted string values to top level key/value-s.}
9
+
10
+ gem.files = `git ls-files`.split($\)
11
+ gem.executables = gem.files.grep(%r{^bin/}).map{ |f| File.basename(f) }
12
+ gem.test_files = gem.files.grep(%r{^(test|spec|features)/})
13
+ gem.require_paths = ['lib']
14
+
15
+ gem.add_development_dependency 'rake'
16
+ gem.add_development_dependency 'fluentd'
17
+ gem.add_runtime_dependency 'fluentd'
18
+ end
@@ -0,0 +1,46 @@
1
+ require 'json'
2
+
3
+ module Fluent
4
+ class FlattenOutput < Output
5
+ class Error < StandardError; end
6
+
7
+ Fluent::Plugin.register_output('flatten', self)
8
+ config_param :key, :string
9
+
10
+ def emit(tag, es, chain)
11
+ es.each do |time, record|
12
+ Engine.emit(tag, time, flatten(record))
13
+ end
14
+
15
+ chain.next
16
+ end
17
+
18
+ def flatten(record)
19
+ if record.has_key?(@key)
20
+ hash = JSON.parse(record[@key])
21
+ record = record.merge(_flatten(@key, hash))
22
+ end
23
+
24
+ record
25
+ end
26
+
27
+ def _flatten(root, hash)
28
+ unless hash.is_a?(Hash)
29
+ raise Error.new('The value to be flattened must be a Hash: #{hash}')
30
+ end
31
+
32
+ flattened = {}
33
+ hash.each do |path, value|
34
+ key = [root, path].join('.')
35
+
36
+ if value.is_a?(String)
37
+ flattened[key] = value
38
+ else
39
+ flattened = flattened.merge(_flatten(key, value))
40
+ end
41
+ end
42
+
43
+ flattened
44
+ end
45
+ end
46
+ end
@@ -0,0 +1,39 @@
1
+ require 'test_helper'
2
+
3
+ class FlattenOutputTest < Test::Unit::TestCase
4
+ def setup
5
+ Fluent::Test.setup
6
+ end
7
+
8
+ def create_driver(conf, tag = 'test')
9
+ Fluent::Test::OutputTestDriver.new(Fluent::FlattenOutput, tag).configure(conf)
10
+ end
11
+
12
+ def test_configure
13
+ d = create_driver(%[
14
+ key foo
15
+ ])
16
+
17
+ assert_equal 'foo', d.instance.key
18
+ end
19
+
20
+ def test_emit
21
+ d = create_driver(%[
22
+ key foo
23
+ ])
24
+
25
+ d.run do
26
+ d.emit( 'foo' => '{"bar" : "baz"}', 'hoge' => 'fuga' )
27
+ d.emit( 'foo' => '{"bar" : {"qux" : "quux", "hoe" : "poe" }, "baz" : "bazz" }', 'hoge' => 'fuga' )
28
+ end
29
+ emits = d.emits
30
+
31
+ assert_equal 3, emits[0][2].count
32
+ assert_equal 'baz', emits[0][2]['foo.bar']
33
+
34
+ assert_equal 5, emits[1][2].count
35
+ assert_equal 'quux', emits[1][2]['foo.bar.qux']
36
+ assert_equal 'poe', emits[1][2]['foo.bar.hoe']
37
+ assert_equal 'bazz', emits[1][2]['foo.baz']
38
+ end
39
+ end
@@ -0,0 +1,32 @@
1
+ require 'rubygems'
2
+ require 'bundler'
3
+
4
+ begin
5
+ Bundler.setup(:default, :development)
6
+ rescue Bundler::BundlerError => e
7
+ $stderr.puts e.message
8
+ $stderr.puts "Run `bundle install` to install missing gems"
9
+ exit e.status_code
10
+ end
11
+
12
+ require 'test/unit'
13
+
14
+ $LOAD_PATH.unshift(File.join(File.dirname(__FILE__), '..', 'lib'))
15
+ $LOAD_PATH.unshift(File.dirname(__FILE__))
16
+
17
+ require 'fluent/test'
18
+
19
+ unless ENV.has_key?('VERBOSE')
20
+ nulllogger = Object.new
21
+ nulllogger.instance_eval {|obj|
22
+ def method_missing(method, *args)
23
+ # pass
24
+ end
25
+ }
26
+ $log = nulllogger
27
+ end
28
+
29
+ require 'fluent/plugin/out_flatten'
30
+
31
+ class Test::Unit::TestCase
32
+ end
metadata ADDED
@@ -0,0 +1,104 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: fluent-plugin-flatten
3
+ version: !ruby/object:Gem::Version
4
+ version: 0.0.1
5
+ prerelease:
6
+ platform: ruby
7
+ authors:
8
+ - Kentaro Kuribayashi
9
+ autorequire:
10
+ bindir: bin
11
+ cert_chain: []
12
+ date: 2012-11-27 00:00:00.000000000 Z
13
+ dependencies:
14
+ - !ruby/object:Gem::Dependency
15
+ name: rake
16
+ requirement: !ruby/object:Gem::Requirement
17
+ none: false
18
+ requirements:
19
+ - - ! '>='
20
+ - !ruby/object:Gem::Version
21
+ version: '0'
22
+ type: :development
23
+ prerelease: false
24
+ version_requirements: !ruby/object:Gem::Requirement
25
+ none: false
26
+ requirements:
27
+ - - ! '>='
28
+ - !ruby/object:Gem::Version
29
+ version: '0'
30
+ - !ruby/object:Gem::Dependency
31
+ name: fluentd
32
+ requirement: !ruby/object:Gem::Requirement
33
+ none: false
34
+ requirements:
35
+ - - ! '>='
36
+ - !ruby/object:Gem::Version
37
+ version: '0'
38
+ type: :development
39
+ prerelease: false
40
+ version_requirements: !ruby/object:Gem::Requirement
41
+ none: false
42
+ requirements:
43
+ - - ! '>='
44
+ - !ruby/object:Gem::Version
45
+ version: '0'
46
+ - !ruby/object:Gem::Dependency
47
+ name: fluentd
48
+ requirement: !ruby/object:Gem::Requirement
49
+ none: false
50
+ requirements:
51
+ - - ! '>='
52
+ - !ruby/object:Gem::Version
53
+ version: '0'
54
+ type: :runtime
55
+ prerelease: false
56
+ version_requirements: !ruby/object:Gem::Requirement
57
+ none: false
58
+ requirements:
59
+ - - ! '>='
60
+ - !ruby/object:Gem::Version
61
+ version: '0'
62
+ description: Fluentd plugin to flatten JSON-formatted string values to top level key/value-s.
63
+ email:
64
+ - kentarok@gmail.com
65
+ executables: []
66
+ extensions: []
67
+ extra_rdoc_files: []
68
+ files:
69
+ - .gitignore
70
+ - Gemfile
71
+ - LICENSE
72
+ - README.md
73
+ - Rakefile
74
+ - fluent-plugin-flatten.gemspec
75
+ - lib/fluent/plugin/out_flatten.rb
76
+ - test/plugin/test_out_flatten.rb
77
+ - test/test_helper.rb
78
+ homepage: http://github.com/kentaro/fluent-plugin-flatten
79
+ licenses: []
80
+ post_install_message:
81
+ rdoc_options: []
82
+ require_paths:
83
+ - lib
84
+ required_ruby_version: !ruby/object:Gem::Requirement
85
+ none: false
86
+ requirements:
87
+ - - ! '>='
88
+ - !ruby/object:Gem::Version
89
+ version: '0'
90
+ required_rubygems_version: !ruby/object:Gem::Requirement
91
+ none: false
92
+ requirements:
93
+ - - ! '>='
94
+ - !ruby/object:Gem::Version
95
+ version: '0'
96
+ requirements: []
97
+ rubyforge_project:
98
+ rubygems_version: 1.8.23
99
+ signing_key:
100
+ specification_version: 3
101
+ summary: Fluentd plugin to flatten JSON-formatted string values to top level key/value-s.
102
+ test_files:
103
+ - test/plugin/test_out_flatten.rb
104
+ - test/test_helper.rb