fluent-plugin-netflowipfix 1.0.0

Sign up to get free protection for your applications and to get access to all the features.
checksums.yaml ADDED
@@ -0,0 +1,7 @@
1
+ ---
2
+ SHA1:
3
+ metadata.gz: 5c262f1d06e957012b081fc752fd4552ee5bcf57
4
+ data.tar.gz: 45aef55456c7de2de658eb15a948e78c6411a731
5
+ SHA512:
6
+ metadata.gz: 7cabd5c57778797095023ea89c4bd480a3bcff7ee13a41ebda246295ce2caee006c4e9fcd771728d14b8ae1d4a6feb8864140480b40383a4a1cb5d7e890fd1d9
7
+ data.tar.gz: df8a136a483827a82103a14f8d943f8649292d96ac9044be093e4564aa693ea928832d0026603eb8a347f9dab238955b49fd202f2945e8be33d9f62ebaaf1087
data/Gemfile ADDED
@@ -0,0 +1,3 @@
1
+ source "https://rubygems.org"
2
+
3
+ gemspec
data/LICENSE ADDED
@@ -0,0 +1,202 @@
1
+
2
+ Apache License
3
+ Version 2.0, January 2004
4
+ http://www.apache.org/licenses/
5
+
6
+ TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION
7
+
8
+ 1. Definitions.
9
+
10
+ "License" shall mean the terms and conditions for use, reproduction,
11
+ and distribution as defined by Sections 1 through 9 of this document.
12
+
13
+ "Licensor" shall mean the copyright owner or entity authorized by
14
+ the copyright owner that is granting the License.
15
+
16
+ "Legal Entity" shall mean the union of the acting entity and all
17
+ other entities that control, are controlled by, or are under common
18
+ control with that entity. For the purposes of this definition,
19
+ "control" means (i) the power, direct or indirect, to cause the
20
+ direction or management of such entity, whether by contract or
21
+ otherwise, or (ii) ownership of fifty percent (50%) or more of the
22
+ outstanding shares, or (iii) beneficial ownership of such entity.
23
+
24
+ "You" (or "Your") shall mean an individual or Legal Entity
25
+ exercising permissions granted by this License.
26
+
27
+ "Source" form shall mean the preferred form for making modifications,
28
+ including but not limited to software source code, documentation
29
+ source, and configuration files.
30
+
31
+ "Object" form shall mean any form resulting from mechanical
32
+ transformation or translation of a Source form, including but
33
+ not limited to compiled object code, generated documentation,
34
+ and conversions to other media types.
35
+
36
+ "Work" shall mean the work of authorship, whether in Source or
37
+ Object form, made available under the License, as indicated by a
38
+ copyright notice that is included in or attached to the work
39
+ (an example is provided in the Appendix below).
40
+
41
+ "Derivative Works" shall mean any work, whether in Source or Object
42
+ form, that is based on (or derived from) the Work and for which the
43
+ editorial revisions, annotations, elaborations, or other modifications
44
+ represent, as a whole, an original work of authorship. For the purposes
45
+ of this License, Derivative Works shall not include works that remain
46
+ separable from, or merely link (or bind by name) to the interfaces of,
47
+ the Work and Derivative Works thereof.
48
+
49
+ "Contribution" shall mean any work of authorship, including
50
+ the original version of the Work and any modifications or additions
51
+ to that Work or Derivative Works thereof, that is intentionally
52
+ submitted to Licensor for inclusion in the Work by the copyright owner
53
+ or by an individual or Legal Entity authorized to submit on behalf of
54
+ the copyright owner. For the purposes of this definition, "submitted"
55
+ means any form of electronic, verbal, or written communication sent
56
+ to the Licensor or its representatives, including but not limited to
57
+ communication on electronic mailing lists, source code control systems,
58
+ and issue tracking systems that are managed by, or on behalf of, the
59
+ Licensor for the purpose of discussing and improving the Work, but
60
+ excluding communication that is conspicuously marked or otherwise
61
+ designated in writing by the copyright owner as "Not a Contribution."
62
+
63
+ "Contributor" shall mean Licensor and any individual or Legal Entity
64
+ on behalf of whom a Contribution has been received by Licensor and
65
+ subsequently incorporated within the Work.
66
+
67
+ 2. Grant of Copyright License. Subject to the terms and conditions of
68
+ this License, each Contributor hereby grants to You a perpetual,
69
+ worldwide, non-exclusive, no-charge, royalty-free, irrevocable
70
+ copyright license to reproduce, prepare Derivative Works of,
71
+ publicly display, publicly perform, sublicense, and distribute the
72
+ Work and such Derivative Works in Source or Object form.
73
+
74
+ 3. Grant of Patent License. Subject to the terms and conditions of
75
+ this License, each Contributor hereby grants to You a perpetual,
76
+ worldwide, non-exclusive, no-charge, royalty-free, irrevocable
77
+ (except as stated in this section) patent license to make, have made,
78
+ use, offer to sell, sell, import, and otherwise transfer the Work,
79
+ where such license applies only to those patent claims licensable
80
+ by such Contributor that are necessarily infringed by their
81
+ Contribution(s) alone or by combination of their Contribution(s)
82
+ with the Work to which such Contribution(s) was submitted. If You
83
+ institute patent litigation against any entity (including a
84
+ cross-claim or counterclaim in a lawsuit) alleging that the Work
85
+ or a Contribution incorporated within the Work constitutes direct
86
+ or contributory patent infringement, then any patent licenses
87
+ granted to You under this License for that Work shall terminate
88
+ as of the date such litigation is filed.
89
+
90
+ 4. Redistribution. You may reproduce and distribute copies of the
91
+ Work or Derivative Works thereof in any medium, with or without
92
+ modifications, and in Source or Object form, provided that You
93
+ meet the following conditions:
94
+
95
+ (a) You must give any other recipients of the Work or
96
+ Derivative Works a copy of this License; and
97
+
98
+ (b) You must cause any modified files to carry prominent notices
99
+ stating that You changed the files; and
100
+
101
+ (c) You must retain, in the Source form of any Derivative Works
102
+ that You distribute, all copyright, patent, trademark, and
103
+ attribution notices from the Source form of the Work,
104
+ excluding those notices that do not pertain to any part of
105
+ the Derivative Works; and
106
+
107
+ (d) If the Work includes a "NOTICE" text file as part of its
108
+ distribution, then any Derivative Works that You distribute must
109
+ include a readable copy of the attribution notices contained
110
+ within such NOTICE file, excluding those notices that do not
111
+ pertain to any part of the Derivative Works, in at least one
112
+ of the following places: within a NOTICE text file distributed
113
+ as part of the Derivative Works; within the Source form or
114
+ documentation, if provided along with the Derivative Works; or,
115
+ within a display generated by the Derivative Works, if and
116
+ wherever such third-party notices normally appear. The contents
117
+ of the NOTICE file are for informational purposes only and
118
+ do not modify the License. You may add Your own attribution
119
+ notices within Derivative Works that You distribute, alongside
120
+ or as an addendum to the NOTICE text from the Work, provided
121
+ that such additional attribution notices cannot be construed
122
+ as modifying the License.
123
+
124
+ You may add Your own copyright statement to Your modifications and
125
+ may provide additional or different license terms and conditions
126
+ for use, reproduction, or distribution of Your modifications, or
127
+ for any such Derivative Works as a whole, provided Your use,
128
+ reproduction, and distribution of the Work otherwise complies with
129
+ the conditions stated in this License.
130
+
131
+ 5. Submission of Contributions. Unless You explicitly state otherwise,
132
+ any Contribution intentionally submitted for inclusion in the Work
133
+ by You to the Licensor shall be under the terms and conditions of
134
+ this License, without any additional terms or conditions.
135
+ Notwithstanding the above, nothing herein shall supersede or modify
136
+ the terms of any separate license agreement you may have executed
137
+ with Licensor regarding such Contributions.
138
+
139
+ 6. Trademarks. This License does not grant permission to use the trade
140
+ names, trademarks, service marks, or product names of the Licensor,
141
+ except as required for reasonable and customary use in describing the
142
+ origin of the Work and reproducing the content of the NOTICE file.
143
+
144
+ 7. Disclaimer of Warranty. Unless required by applicable law or
145
+ agreed to in writing, Licensor provides the Work (and each
146
+ Contributor provides its Contributions) on an "AS IS" BASIS,
147
+ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
148
+ implied, including, without limitation, any warranties or conditions
149
+ of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A
150
+ PARTICULAR PURPOSE. You are solely responsible for determining the
151
+ appropriateness of using or redistributing the Work and assume any
152
+ risks associated with Your exercise of permissions under this License.
153
+
154
+ 8. Limitation of Liability. In no event and under no legal theory,
155
+ whether in tort (including negligence), contract, or otherwise,
156
+ unless required by applicable law (such as deliberate and grossly
157
+ negligent acts) or agreed to in writing, shall any Contributor be
158
+ liable to You for damages, including any direct, indirect, special,
159
+ incidental, or consequential damages of any character arising as a
160
+ result of this License or out of the use or inability to use the
161
+ Work (including but not limited to damages for loss of goodwill,
162
+ work stoppage, computer failure or malfunction, or any and all
163
+ other commercial damages or losses), even if such Contributor
164
+ has been advised of the possibility of such damages.
165
+
166
+ 9. Accepting Warranty or Additional Liability. While redistributing
167
+ the Work or Derivative Works thereof, You may choose to offer,
168
+ and charge a fee for, acceptance of support, warranty, indemnity,
169
+ or other liability obligations and/or rights consistent with this
170
+ License. However, in accepting such obligations, You may act only
171
+ on Your own behalf and on Your sole responsibility, not on behalf
172
+ of any other Contributor, and only if You agree to indemnify,
173
+ defend, and hold each Contributor harmless for any liability
174
+ incurred by, or claims asserted against, such Contributor by reason
175
+ of your accepting any such warranty or additional liability.
176
+
177
+ END OF TERMS AND CONDITIONS
178
+
179
+ APPENDIX: How to apply the Apache License to your work.
180
+
181
+ To apply the Apache License to your work, attach the following
182
+ boilerplate notice, with the fields enclosed by brackets "[]"
183
+ replaced with your own identifying information. (Don't include
184
+ the brackets!) The text should be enclosed in the appropriate
185
+ comment syntax for the file format. We also recommend that a
186
+ file or class name and description of purpose be included on the
187
+ same "printed page" as the copyright notice for easier
188
+ identification within third-party archives.
189
+
190
+ Copyright [yyyy] [name of copyright owner]
191
+
192
+ Licensed under the Apache License, Version 2.0 (the "License");
193
+ you may not use this file except in compliance with the License.
194
+ You may obtain a copy of the License at
195
+
196
+ http://www.apache.org/licenses/LICENSE-2.0
197
+
198
+ Unless required by applicable law or agreed to in writing, software
199
+ distributed under the License is distributed on an "AS IS" BASIS,
200
+ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
201
+ See the License for the specific language governing permissions and
202
+ limitations under the License.
data/README.md ADDED
@@ -0,0 +1,83 @@
1
+ # Netflow(v5/v9) and IPfix(v10) plugin for Fluentd
2
+ # fluent-plugin-netflowipfix
3
+
4
+ [Fluentd](https://fluentd.org/) input plugin that acts as Netflow v5/v9 and IPfix (v10) collector.
5
+
6
+
7
+ ## Installation
8
+
9
+ ### RubyGems
10
+
11
+ ```
12
+ $ gem install fluent-plugin-netflowipfix
13
+ ```
14
+
15
+ ### Bundler
16
+
17
+ Add following line to your Gemfile:
18
+
19
+ ```ruby
20
+ gem "fluent-plugin-netflowipfix"
21
+ ```
22
+
23
+ And then execute:
24
+
25
+ ```
26
+ $ bundle
27
+ ```
28
+
29
+ ## Configuration
30
+
31
+
32
+ <source>
33
+ type netflowipfix
34
+ tag netflow.event
35
+
36
+ # optional parameters
37
+ bind 192.168.0.1
38
+ port 2055
39
+ cache_ttl 6000
40
+ definitions /path/to/custom_fields.yaml
41
+ </source>
42
+
43
+ **bind**
44
+
45
+ IP address on which the plugin will accept Netflow.
46
+ (Default: '0.0.0.0')
47
+
48
+ **port**
49
+
50
+ UDP port number on which tpe plugin will accept Netflow.
51
+ (Default: 5140)
52
+
53
+ **cache_ttl**
54
+
55
+ Template cache TTL for Netflow v9 or IPfix v10 in seconds. Templates not refreshed from the Netflow v9 exporter within the TTL are expired at the plugin.
56
+ (Default: 4000)
57
+
58
+ **switched_times_from_uptime**
59
+
60
+ When set to true, the plugin stores system uptime for ```first_switched``` and ```last_switched``` instead of ISO8601-formatted absolute time.
61
+ (Defaults: false)
62
+ TODO: This is currently disabled
63
+
64
+ **definitions**
65
+
66
+ YAML file containing Netflow field definitions to overfide pre-defined templates. Example is like below
67
+
68
+ ---
69
+ 4: # field value
70
+ - :uint8 # field length
71
+ - :protocol # field type
72
+
73
+ ## Pending
74
+
75
+ * Tests
76
+ * A few TODOs in the code
77
+
78
+ ## Copyright
79
+
80
+ * Copyright(c) 2018- Yves Desharnais
81
+ * License
82
+ * Apache License, Version 2.0
83
+
data/Rakefile ADDED
@@ -0,0 +1,13 @@
1
+ require "bundler"
2
+ Bundler::GemHelper.install_tasks
3
+
4
+ require "rake/testtask"
5
+
6
+ Rake::TestTask.new(:test) do |t|
7
+ t.libs.push("lib", "test")
8
+ t.test_files = FileList["test/**/test_*.rb"]
9
+ t.verbose = true
10
+ t.warning = true
11
+ end
12
+
13
+ task default: [:test]
@@ -0,0 +1,28 @@
1
+ lib = File.expand_path("../lib", __FILE__)
2
+ $LOAD_PATH.unshift(lib) unless $LOAD_PATH.include?(lib)
3
+
4
+ Gem::Specification.new do |spec|
5
+ spec.name = "fluent-plugin-netflowipfix"
6
+ spec.version = "1.0.0"
7
+ spec.authors = ["Yves Desharnaus"]
8
+ spec.email = ["yvesbd@gmail.com"]
9
+
10
+ spec.summary = %q{Fluentd Netflow (v5, v9) and IpFix (v10) Input plugin.}
11
+ spec.description = %q{Created to replace and add missing functionality to the fluent-plugin-netflow fluentd plugin.}
12
+ spec.homepage = "https://github.com/yvesbd/fluent-plugin-netflowipfix"
13
+ spec.license = "Apache-2.0"
14
+
15
+ test_files, files = `git ls-files -z`.split("\x0").partition do |f|
16
+ f.match(%r{^(test|spec|features)/})
17
+ end
18
+ spec.files = files
19
+ spec.executables = files.grep(%r{^bin/}) { |f| File.basename(f) }
20
+ spec.test_files = test_files
21
+ spec.require_paths = ["lib"]
22
+
23
+ # spec.add_development_dependency "bundler", "~> 1.14"
24
+ spec.add_development_dependency "rake", "~> 12.0"
25
+ spec.add_development_dependency "test-unit", "~> 3.0"
26
+ spec.add_runtime_dependency "fluentd", [">= 0.14.10", "< 2"]
27
+ spec.add_runtime_dependency "bindata", "~> 2.1"
28
+ end
data/lib/.DS_Store ADDED
Binary file
Binary file
@@ -0,0 +1,161 @@
1
+ #
2
+ # Copyright 2018 Yves Desharnais
3
+ #
4
+ # Licensed under the Apache License, Version 2.0 (the "License");
5
+ # you may not use this file except in compliance with the License.
6
+ # You may obtain a copy of the License at
7
+ #
8
+ # http://www.apache.org/licenses/LICENSE-2.0
9
+ #
10
+ # Unless required by applicable law or agreed to in writing, software
11
+ # distributed under the License is distributed on an "AS IS" BASIS,
12
+ # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13
+ # See the License for the specific language governing permissions and
14
+ # limitations under the License.
15
+
16
+ require "fluent/plugin/input"
17
+ require 'cool.io'
18
+ require 'fluent/plugin/socket_util'
19
+ # require_relative 'parser_netflowipfix'
20
+ require_relative 'parser_netflow_v5'
21
+ require_relative 'parser_netflow_v9'
22
+ require_relative 'netflowipfix_records'
23
+ require_relative 'vash'
24
+
25
+ module Fluent
26
+ module Plugin
27
+ class NetflowipfixInput < Fluent::Plugin::Input
28
+ Fluent::Plugin.register_input("netflowipfix", self)
29
+
30
+ config_param :cache_ttl, :integer, default: 4000
31
+ config_param :definitions, :string, default: nil
32
+
33
+ config_param :debug, :bool, default: false
34
+ config_param :port, :integer, default: 5140
35
+ config_param :bind, :string, default: '0.0.0.0'
36
+ config_param :tag, :string
37
+ config_param :protocol_type, default: :udp do |val|
38
+ case val.downcase
39
+ when 'udp'
40
+ :udp
41
+ else
42
+ raise ConfigError, "netflow input protocol type should be 'udp'"
43
+ end
44
+ end # config_param :protocol_type
45
+
46
+ def configure(conf)
47
+ super
48
+ @nbpackets = 0
49
+ @parser_v5 = ParserNetflowv5.new
50
+ @parser_v9 = ParserNetflowv9.new
51
+ @parser_v9.configure(@cache_ttl, @definitions)
52
+ @parser_v10 = ParserIPfixv10.new
53
+ @parser_v10.configure(@cache_ttl, @definitions)
54
+ end # def configure
55
+
56
+ def start
57
+ @loop = Coolio::Loop.new
58
+ @handler = listen(method(:receive_data))
59
+ @loop.attach(@handler)
60
+ @thread = Thread.new(&method(:run))
61
+ end # def start
62
+
63
+ def shutdown
64
+ @loop.watchers.each { |w| w.detach }
65
+ @loop.stop
66
+ @handler.close
67
+ @thread.join
68
+ end # def shutdown
69
+
70
+ def run
71
+ @loop.run
72
+ rescue => e
73
+ log.error "unexpected error", error_class: e.class, error: e.message
74
+ log.error_backtrace
75
+ end # def run
76
+
77
+ protected
78
+
79
+ def receive_data(host, data)
80
+ # if (@debug)
81
+ # log.on_debug { log.debug "received logs", :host => host, :data => data }
82
+ call(data, host) { |time, record|
83
+ unless time && record
84
+ log.warn "pattern not match: #{data.inspect}"
85
+ return
86
+ end
87
+
88
+ # if (@debug) log.info "ready to emit ", time:time, tag:@tag
89
+
90
+ record['host'] = host
91
+ router.emit(@tag, EventTime.new(time), record)
92
+ } # call
93
+ rescue => e
94
+ log.warn "unexpected error on parsing", data: data.dump, error_class: e.class, error: e.message
95
+ log.warn_backtrace
96
+ end # def receive_data
97
+
98
+ private
99
+
100
+ def listen(callback)
101
+ log.info "listening netflow socket on #{@bind}:#{@port} with #{@protocol_type}"
102
+ if @protocol_type == :udp
103
+ @usock = SocketUtil.create_udp_socket(@bind)
104
+ @usock.bind(@bind, @port)
105
+ UdpHandler.new(@usock, callback)
106
+ else
107
+ Coolio::TCPServer.new(@bind, @port, TcpHandler, log, callback)
108
+ end
109
+ end # def listen
110
+
111
+ def call(payload, host=nil, &block)
112
+ version,_ = payload[0,2].unpack('n')
113
+ @nbpackets += 1
114
+ # nb = @nbpackets
115
+ if (@debug)
116
+ log.debug "Packet #{@nbpackets} with version #{version}"
117
+ end
118
+ case version
119
+ when 5
120
+ packet = Netflow5Packet.read(payload)
121
+ @parser_v5.handle_v5(host, packet, block)
122
+ when 9
123
+ packet = Netflow9Packet.read(payload)
124
+ @parser_v9.handle_v9(host, packet, block)
125
+ when 10
126
+ packet = Netflow10Packet.read(payload)
127
+ @parser_v10.handle_v10(host, packet, block)
128
+ else
129
+ $log.warn "Unsupported Netflow version v#{version}: #{version.class}"
130
+ end # case
131
+ end # def call
132
+
133
+ end # class NetflowipfixInput
134
+
135
+ class UdpHandler < Coolio::IO
136
+ def initialize(io, callback)
137
+ super(io)
138
+ @io = io
139
+ @callback = callback
140
+ end # def initialize
141
+
142
+ def on_readable
143
+ msg, addr = @io.recvfrom_nonblock(4096)
144
+ @callback.call(addr[3], msg)
145
+ rescue => e
146
+ log.error "unexpected error on reading from socket", error_class: e.class, error: e.message
147
+ log.error_backtrace
148
+ end # def on_readable
149
+ end # class UdpHandler
150
+
151
+
152
+ end # module Plugin
153
+ end # module Fluent
154
+
155
+
156
+
157
+
158
+
159
+
160
+ =begin
161
+ =end