fluent-plugin-verticajson 0.0.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 ADDED
@@ -0,0 +1,7 @@
1
+ ---
2
+ SHA1:
3
+ metadata.gz: 85e6b0afbae7763b096e957a44e8a38a1cd67926
4
+ data.tar.gz: b87cd6701f87574516bbab158f2b78872e0173c2
5
+ SHA512:
6
+ metadata.gz: af06fe2583c3cad268c02aabfc95d83af17ddd3a683115fb86c8d46465d2bc895d2d3119a3242c967c820f07ebf2936125456fabe1b66547f41a69eab3048d20
7
+ data.tar.gz: 5f98dce4e75779e2d3832c0b2bbeebf9c71959830dad842a3eb24cdddd111b131c9432719454d5304b2dac3df0ff1490813367f6c64e6a10aca02a94189f745e
@@ -0,0 +1,69 @@
1
+ module Fluent
2
+ class VerticaJsonOutput < Fluent::BufferedOutput
3
+ Fluent::Plugin.register_output('verticajson', self)
4
+
5
+ config_param :host, :string, :default => '127.0.0.1'
6
+ config_param :port, :integer, :default => 5433
7
+ config_param :username, :string, :default => 'dbadmin'
8
+ config_param :password, :string, :default => nil
9
+ config_param :database, :string, :default => nil
10
+ config_param :schema, :string, :default => nil
11
+ config_param :table, :string, :default => nil
12
+ config_param :ssl, :bool, :default => false
13
+
14
+ def initialize
15
+ super
16
+
17
+ require 'vertica'
18
+ require 'json'
19
+ end
20
+
21
+ def format(tag, time, record)
22
+ record_altered = Hash[
23
+ record.map{ |k, v|
24
+ if v.is_a?(Hash) or v.is_a?(Array)
25
+ [k, "#{v}"]
26
+ else
27
+ [k, v]
28
+ end
29
+ }
30
+ ]
31
+
32
+ $log.info "New data received to the buffer for the table #{@schema}.#{@table}"
33
+ record_altered.to_json
34
+ end
35
+
36
+ def write(chunk)
37
+ perm_table = "#{@schema}.#{@table}"
38
+
39
+ chunk.open do |file|
40
+
41
+ file_contents = file.read
42
+
43
+ vertica.copy(<<-SQL) { |handle| handle.write(file_contents) }
44
+ COPY #{perm_table}
45
+ FROM STDIN
46
+ PARSER fjsonparser()
47
+ ENFORCELENGTH DIRECT
48
+ REJECTED DATA AS TABLE #{@table}_rejected
49
+ SQL
50
+
51
+ end
52
+ $log.info "Data successfully loaded to vertica table #{perm_table}."
53
+ end
54
+
55
+ private
56
+
57
+ def vertica
58
+ @vertica ||= Vertica.connect({
59
+ :host => @host,
60
+ :user => @username,
61
+ :password => @password,
62
+ :ssl => @ssl,
63
+ :port => @port,
64
+ :database => @database
65
+ })
66
+ end
67
+
68
+ end
69
+ end
metadata ADDED
@@ -0,0 +1,86 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: fluent-plugin-verticajson
3
+ version: !ruby/object:Gem::Version
4
+ version: 0.0.1
5
+ platform: ruby
6
+ authors:
7
+ - Josef Janda
8
+ autorequire:
9
+ bindir: bin
10
+ cert_chain: []
11
+ date: 2017-10-31 00:00:00.000000000 Z
12
+ dependencies:
13
+ - !ruby/object:Gem::Dependency
14
+ name: fluentd
15
+ requirement: !ruby/object:Gem::Requirement
16
+ requirements:
17
+ - - ~>
18
+ - !ruby/object:Gem::Version
19
+ version: 0.10.35
20
+ type: :runtime
21
+ prerelease: false
22
+ version_requirements: !ruby/object:Gem::Requirement
23
+ requirements:
24
+ - - ~>
25
+ - !ruby/object:Gem::Version
26
+ version: 0.10.35
27
+ - !ruby/object:Gem::Dependency
28
+ name: vertica
29
+ requirement: !ruby/object:Gem::Requirement
30
+ requirements:
31
+ - - '>='
32
+ - !ruby/object:Gem::Version
33
+ version: '0'
34
+ type: :runtime
35
+ prerelease: false
36
+ version_requirements: !ruby/object:Gem::Requirement
37
+ requirements:
38
+ - - '>='
39
+ - !ruby/object:Gem::Version
40
+ version: '0'
41
+ - !ruby/object:Gem::Dependency
42
+ name: json
43
+ requirement: !ruby/object:Gem::Requirement
44
+ requirements:
45
+ - - '>='
46
+ - !ruby/object:Gem::Version
47
+ version: '0'
48
+ type: :runtime
49
+ prerelease: false
50
+ version_requirements: !ruby/object:Gem::Requirement
51
+ requirements:
52
+ - - '>='
53
+ - !ruby/object:Gem::Version
54
+ version: '0'
55
+ description:
56
+ email:
57
+ - josef.janda@wandera.com
58
+ executables: []
59
+ extensions: []
60
+ extra_rdoc_files: []
61
+ files:
62
+ - lib/fluent/plugin/out_verticajson.rb
63
+ homepage:
64
+ licenses: []
65
+ metadata: {}
66
+ post_install_message:
67
+ rdoc_options: []
68
+ require_paths:
69
+ - lib
70
+ required_ruby_version: !ruby/object:Gem::Requirement
71
+ requirements:
72
+ - - '>='
73
+ - !ruby/object:Gem::Version
74
+ version: 1.9.1
75
+ required_rubygems_version: !ruby/object:Gem::Requirement
76
+ requirements:
77
+ - - '>='
78
+ - !ruby/object:Gem::Version
79
+ version: '0'
80
+ requirements: []
81
+ rubyforge_project:
82
+ rubygems_version: 2.0.14.1
83
+ signing_key:
84
+ specification_version: 4
85
+ summary: Fluentd output plugin for Vertica using json parser.
86
+ test_files: []