fluent-plugin-secure-tcp 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 ADDED
@@ -0,0 +1,7 @@
1
+ ---
2
+ SHA1:
3
+ metadata.gz: 44679da42c1e8e68c469840ca507a98829507765
4
+ data.tar.gz: e13301c762731a26c90f6bd2fb313cc474b1fddc
5
+ SHA512:
6
+ metadata.gz: ef0506b91ab583dfef932b12d3d09a39fcd99a23d2e1fd18eabb00cbbc2c8ad71e1f960e4c655fba379409c4e894def56e4a3911b20854bbee5d93cf1afdc7e9
7
+ data.tar.gz: 6631723d1b76b843e972c6457d2fc17f79b22fda7736cfd6733061c26ffdeba94973b0731f6f228be12c1c7412a42fe6744853e6bca880024791638a0192ade7
data/.gitattributes ADDED
@@ -0,0 +1,17 @@
1
+ # Auto detect text files and perform LF normalization
2
+ * text=auto
3
+
4
+ # Custom for Visual Studio
5
+ *.cs diff=csharp
6
+
7
+ # Standard to msysgit
8
+ *.doc diff=astextplain
9
+ *.DOC diff=astextplain
10
+ *.docx diff=astextplain
11
+ *.DOCX diff=astextplain
12
+ *.dot diff=astextplain
13
+ *.DOT diff=astextplain
14
+ *.pdf diff=astextplain
15
+ *.PDF diff=astextplain
16
+ *.rtf diff=astextplain
17
+ *.RTF diff=astextplain
data/.gitignore ADDED
@@ -0,0 +1,11 @@
1
+ /.bundle/
2
+ /.yardoc
3
+ /Gemfile.lock
4
+ /_yardoc/
5
+ /coverage/
6
+ /doc/
7
+ /pkg/
8
+ /spec/reports/
9
+ /tmp/
10
+
11
+ *.yaml
data/.travis.yml ADDED
@@ -0,0 +1,5 @@
1
+ sudo: false
2
+ language: ruby
3
+ rvm:
4
+ - 2.3.1
5
+ before_install: gem install bundler -v 1.13.6
data/Gemfile ADDED
@@ -0,0 +1,4 @@
1
+ source 'https://rubygems.org'
2
+
3
+ # Specify your gem's dependencies in fluent-plugin-secure-tcp.gemspec
4
+ gemspec
data/README.md ADDED
@@ -0,0 +1,36 @@
1
+ # Fluent::Plugin::Secure::Tcp
2
+
3
+ Welcome to your new gem! In this directory, you'll find the files you need to be able to package up your Ruby library into a gem. Put your Ruby code in the file `lib/fluent/plugin/secure/tcp`. To experiment with that code, run `bin/console` for an interactive prompt.
4
+
5
+ TODO: Delete this and the text above, and describe your gem
6
+
7
+ ## Installation
8
+
9
+ Add this line to your application's Gemfile:
10
+
11
+ ```ruby
12
+ gem 'fluent-plugin-secure-tcp'
13
+ ```
14
+
15
+ And then execute:
16
+
17
+ $ bundle
18
+
19
+ Or install it yourself as:
20
+
21
+ $ gem install fluent-plugin-secure-tcp
22
+
23
+ ## Usage
24
+
25
+ TODO: Write usage instructions here
26
+
27
+ ## Development
28
+
29
+ After checking out the repo, run `bin/setup` to install dependencies. Then, run `rake test` to run the tests. You can also run `bin/console` for an interactive prompt that will allow you to experiment.
30
+
31
+ To install this gem onto your local machine, run `bundle exec rake install`. To release a new version, update the version number in `version.rb`, and then run `bundle exec rake release`, which will create a git tag for the version, push git commits and tags, and push the `.gem` file to [rubygems.org](https://rubygems.org).
32
+
33
+ ## Contributing
34
+
35
+ Bug reports and pull requests are welcome on GitHub at https://github.com/[USERNAME]/fluent-plugin-secure-tcp.
36
+
data/Rakefile ADDED
@@ -0,0 +1,10 @@
1
+ require "bundler/gem_tasks"
2
+ require "rake/testtask"
3
+
4
+ Rake::TestTask.new(:test) do |t|
5
+ t.libs << "test"
6
+ t.libs << "lib"
7
+ t.test_files = FileList['test/**/*_test.rb']
8
+ end
9
+
10
+ task :default => :test
data/bin/console ADDED
@@ -0,0 +1,14 @@
1
+ #!/usr/bin/env ruby
2
+
3
+ require "bundler/setup"
4
+ require "fluent/plugin/secure/tcp"
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,29 @@
1
+ # coding: utf-8
2
+ lib = File.expand_path('../lib', __FILE__)
3
+ $LOAD_PATH.unshift(lib) unless $LOAD_PATH.include?(lib)
4
+ require 'fluent/plugin/secure/tcp/version'
5
+
6
+ Gem::Specification.new do |spec|
7
+ spec.name = "fluent-plugin-secure-tcp"
8
+ spec.version = Fluent::Plugin::Secure::Tcp::VERSION
9
+ spec.authors = ["Bohumil Cervenka"]
10
+ spec.email = ["bcervenka1@gmail.com"]
11
+
12
+ spec.description = %q{Secure tcp input plugin for Fluent event collector}
13
+ spec.summary = spec.description
14
+ spec.homepage = 'https://github.com/SilverDragon135/fluent-plugin-in-secure-tcp'
15
+
16
+ spec.files = `git ls-files -z`.split("\x0").reject do |f|
17
+ f.match(%r{^(test|spec|features)/})
18
+ end
19
+ spec.bindir = "exe"
20
+ spec.executables = spec.files.grep(%r{^exe/}) { |f| File.basename(f) }
21
+ spec.require_paths = ["lib"]
22
+
23
+
24
+ spec.add_dependency "fluentd", [">= 0.10.58", "< 2"]
25
+ spec.add_dependency "concurrent-ruby", "~> 0.9.2"
26
+ spec.add_development_dependency "bundler", "~> 1.13"
27
+ spec.add_development_dependency "rake", "~> 10.0"
28
+ spec.add_development_dependency "minitest", "~> 5.0"
29
+ end
@@ -0,0 +1,129 @@
1
+ require 'fluent/input'
2
+ require 'fluent/parser'
3
+ module Fluent
4
+ class SecureTcpInput < Input
5
+ Plugin.register_input('securetcp', self)
6
+
7
+ def initialize
8
+ super
9
+ require "openssl"
10
+ require "socket"
11
+ require 'concurrent/executor/cached_thread_pool'
12
+ end
13
+
14
+ config_param :port, :integer, :default => 5433
15
+ config_param :bind, :string, :default => '0.0.0.0'
16
+ config_param :tag, :string, :default => nil
17
+ config_param :format, :string, :default => nil
18
+ config_param :add_ip, :bool, :default => nil
19
+ config_param :max_connections, :integer, :default => nil # CachedThreadPool can't limit the number of threads
20
+ config_param :ssl_certificate, :string, :default => nil
21
+ config_param :ssl_key, :string, :default => nil
22
+ config_param :ssl_key_passphrase, :string, :default => nil
23
+
24
+ def configure(conf)
25
+ super
26
+ if !@tag && !@ssl_certificate && !@ssl_key
27
+ raise ConfigError, "'tag' and 'ssl_certificate' and 'ssl_key' parameter is required on secure tcp input"
28
+ end
29
+ if @format
30
+ @parser = Plugin.new_parser(@format)
31
+ @parser.configure(conf)
32
+ end
33
+ @connections = []
34
+ end
35
+
36
+ def start
37
+ super
38
+ tcp_client = TCPServer.new(bind,port)
39
+ ssl_context = OpenSSL::SSL::SSLContext.new
40
+ ssl_context.cert = OpenSSL::X509::Certificate.new(File.read(@ssl_certificate))
41
+ if @ssl_key_passphrase
42
+ ssl_context.key = OpenSSL::PKey::RSA.new(File.read(@ssl_key),@ssl_key_passphrase)
43
+ else
44
+ ssl_context.key = OpenSSL::PKey::RSA.new(File.read(@ssl_key))
45
+ end
46
+ @server = OpenSSL::SSL::SSLServer.new(tcp_client, ssl_context)
47
+ @thread_pool = Concurrent::CachedThreadPool.new(:idletime => 50)
48
+ @thread = Thread.new(&method(:run))
49
+ log.info "SSL listening on port: #{bind}:#{port} *"
50
+ end
51
+
52
+ def shutdown
53
+ @server.shutdown rescue nil
54
+ @server.close rescue nil
55
+ @tcp_client.shutdown rescue nil
56
+ @tcp_client.close rescue nil
57
+ @thread_pool.shutdown
58
+ @thread.join
59
+ super
60
+ end
61
+
62
+ def run
63
+ until @server.to_io.closed?
64
+ begin
65
+ conn = @server.accept
66
+ next if conn.nil?
67
+ if @max_connections
68
+ @connections.reject! { |c| c.closed? }
69
+ if @connections.size >= @max_connections
70
+ conn.close # close for retry
71
+ sleep 1
72
+ next
73
+ end
74
+ @connections << conn
75
+ end
76
+
77
+ @thread_pool.post {
78
+ begin
79
+ while buf = conn.gets
80
+ buf = buf.chomp
81
+ to_server = buf
82
+ time = Time.now.getutc
83
+ if @format
84
+ if @format = "json" && @add_ip
85
+ sock_domain, remote_port, remote_hostname, remote_ip = conn.peeraddr
86
+ peer_ip = "\"peer_ip\":\"#{remote_ip}\","
87
+ n = to_server.length
88
+ to_server = "{#{peer_ip}#{to_server.slice(1,n)}"
89
+ end
90
+ @parser.parse(to_server) { |time, record|
91
+ unless time && record
92
+ log.warn "*pattern not match: #{msg.inspect} *"
93
+ next
94
+ end
95
+
96
+ router.emit(tag,time,record)
97
+ }
98
+ else
99
+ if @add_ip
100
+ buff = conn.peeraddr.to_s + " - " + buff
101
+ end
102
+ router.emit(tag,time,buf)
103
+ end
104
+ end
105
+ rescue OpenSSL::SSL::SSLError => e
106
+ conn.close
107
+ log.error "unexpected error", :error => e.to_s
108
+ sleep 1
109
+ rescue => e
110
+ log.error "unexpected error:", :error => e.to_s
111
+ next if e.message == "Connection reset by peer" #supress backtrace on connection reset
112
+ log.error_backtrace
113
+ end
114
+ }
115
+ rescue OpenSSL::SSL::SSLError => e
116
+ conn.close
117
+ log.error "unexpected error", :error => e.to_s
118
+ sleep 1
119
+ rescue => e
120
+ if !@server.to_io.closed? #supress shutdown errors
121
+ log.error "unexpected error", :error => e.to_s
122
+ next if e.message == "Connection reset by peer" #supress backtrace on connection reset
123
+ log.error_backtrace
124
+ end
125
+ end
126
+ end
127
+ end
128
+ end
129
+ end
@@ -0,0 +1,11 @@
1
+ require "fluent/plugin/secure/tcp/version"
2
+
3
+ module Fluent
4
+ module Plugin
5
+ module Secure
6
+ module Tcp
7
+ # Your code goes here...
8
+ end
9
+ end
10
+ end
11
+ end
@@ -0,0 +1,9 @@
1
+ module Fluent
2
+ module Plugin
3
+ module Secure
4
+ module Tcp
5
+ VERSION = "0.1.1"
6
+ end
7
+ end
8
+ end
9
+ end
metadata ADDED
@@ -0,0 +1,131 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: fluent-plugin-secure-tcp
3
+ version: !ruby/object:Gem::Version
4
+ version: 0.1.1
5
+ platform: ruby
6
+ authors:
7
+ - Bohumil Cervenka
8
+ autorequire:
9
+ bindir: exe
10
+ cert_chain: []
11
+ date: 2016-11-25 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.58
20
+ - - "<"
21
+ - !ruby/object:Gem::Version
22
+ version: '2'
23
+ type: :runtime
24
+ prerelease: false
25
+ version_requirements: !ruby/object:Gem::Requirement
26
+ requirements:
27
+ - - ">="
28
+ - !ruby/object:Gem::Version
29
+ version: 0.10.58
30
+ - - "<"
31
+ - !ruby/object:Gem::Version
32
+ version: '2'
33
+ - !ruby/object:Gem::Dependency
34
+ name: concurrent-ruby
35
+ requirement: !ruby/object:Gem::Requirement
36
+ requirements:
37
+ - - "~>"
38
+ - !ruby/object:Gem::Version
39
+ version: 0.9.2
40
+ type: :runtime
41
+ prerelease: false
42
+ version_requirements: !ruby/object:Gem::Requirement
43
+ requirements:
44
+ - - "~>"
45
+ - !ruby/object:Gem::Version
46
+ version: 0.9.2
47
+ - !ruby/object:Gem::Dependency
48
+ name: bundler
49
+ requirement: !ruby/object:Gem::Requirement
50
+ requirements:
51
+ - - "~>"
52
+ - !ruby/object:Gem::Version
53
+ version: '1.13'
54
+ type: :development
55
+ prerelease: false
56
+ version_requirements: !ruby/object:Gem::Requirement
57
+ requirements:
58
+ - - "~>"
59
+ - !ruby/object:Gem::Version
60
+ version: '1.13'
61
+ - !ruby/object:Gem::Dependency
62
+ name: rake
63
+ requirement: !ruby/object:Gem::Requirement
64
+ requirements:
65
+ - - "~>"
66
+ - !ruby/object:Gem::Version
67
+ version: '10.0'
68
+ type: :development
69
+ prerelease: false
70
+ version_requirements: !ruby/object:Gem::Requirement
71
+ requirements:
72
+ - - "~>"
73
+ - !ruby/object:Gem::Version
74
+ version: '10.0'
75
+ - !ruby/object:Gem::Dependency
76
+ name: minitest
77
+ requirement: !ruby/object:Gem::Requirement
78
+ requirements:
79
+ - - "~>"
80
+ - !ruby/object:Gem::Version
81
+ version: '5.0'
82
+ type: :development
83
+ prerelease: false
84
+ version_requirements: !ruby/object:Gem::Requirement
85
+ requirements:
86
+ - - "~>"
87
+ - !ruby/object:Gem::Version
88
+ version: '5.0'
89
+ description: Secure tcp input plugin for Fluent event collector
90
+ email:
91
+ - bcervenka1@gmail.com
92
+ executables: []
93
+ extensions: []
94
+ extra_rdoc_files: []
95
+ files:
96
+ - ".gitattributes"
97
+ - ".gitignore"
98
+ - ".travis.yml"
99
+ - Gemfile
100
+ - README.md
101
+ - Rakefile
102
+ - bin/console
103
+ - bin/setup
104
+ - fluent-plugin-secure-tcp.gemspec
105
+ - lib/fluent/plugin/in_securetcp.rb
106
+ - lib/fluent/plugin/secure/tcp.rb
107
+ - lib/fluent/plugin/secure/tcp/version.rb
108
+ homepage: https://github.com/SilverDragon135/fluent-plugin-in-secure-tcp
109
+ licenses: []
110
+ metadata: {}
111
+ post_install_message:
112
+ rdoc_options: []
113
+ require_paths:
114
+ - lib
115
+ required_ruby_version: !ruby/object:Gem::Requirement
116
+ requirements:
117
+ - - ">="
118
+ - !ruby/object:Gem::Version
119
+ version: '0'
120
+ required_rubygems_version: !ruby/object:Gem::Requirement
121
+ requirements:
122
+ - - ">="
123
+ - !ruby/object:Gem::Version
124
+ version: '0'
125
+ requirements: []
126
+ rubyforge_project:
127
+ rubygems_version: 2.5.1
128
+ signing_key:
129
+ specification_version: 4
130
+ summary: Secure tcp input plugin for Fluent event collector
131
+ test_files: []