sensu-plugins-tripwire 0.0.1

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: 4aafd7549cc2ebf329e2d7a5573b0b0286da4c1f
4
+ data.tar.gz: 5dbc17f62d556f04afc822bc4abc4d525a24870e
5
+ SHA512:
6
+ metadata.gz: 7a8679bb217b168707b91394f9ef7b2fa10ff166023a5bf77cfad1e4b428381bda7e11e1efee08f91375594d6043df0559da2f5d2349f68e5156961bbae03abe
7
+ data.tar.gz: 214d05d70e5018d923dd0aa1013c2db206f3a0b2f6a1d9e7ebb6464bf0f78f490e87ddfd723224b4eb424b027d6eb4ad7e882d143458d3967904c7c9fb5e8959
checksums.yaml.gz.sig ADDED
Binary file
data.tar.gz.sig ADDED
Binary file
data/CHANGELOG.md ADDED
@@ -0,0 +1,11 @@
1
+ #Change Log
2
+ This project adheres to [Semantic Versioning](http://semver.org/).
3
+
4
+ This CHANGELOG follows the format listed at [Keep A Changelog](http://keepachangelog.com/)
5
+
6
+ ## Unreleased][unreleased]
7
+
8
+ ## 0.0.1 - 2015-05-20
9
+
10
+ ### Added
11
+ - initial release
data/LICENSE ADDED
@@ -0,0 +1,22 @@
1
+ Copyright (c) 2015 Sensu-Plugins
2
+
3
+ MIT License
4
+
5
+ Permission is hereby granted, free of charge, to any person obtaining
6
+ a copy of this software and associated documentation files (the
7
+ "Software"), to deal in the Software without restriction, including
8
+ without limitation the rights to use, copy, modify, merge, publish,
9
+ distribute, sublicense, and/or sell copies of the Software, and to
10
+ permit persons to whom the Software is furnished to do so, subject to
11
+ the following conditions:
12
+
13
+ The above copyright notice and this permission notice shall be
14
+ included in all copies or substantial portions of the Software.
15
+
16
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
17
+ EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
18
+ MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
19
+ NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
20
+ LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
21
+ OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
22
+ WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
data/README.md ADDED
@@ -0,0 +1,22 @@
1
+ ## Sensu-Plugins-tripwire
2
+
3
+ [![Build Status](https://travis-ci.org/sensu-plugins/sensu-plugins-tripwire.svg?branch=master)](https://travis-ci.org/sensu-plugins/sensu-plugins-tripwire)
4
+ [![Gem Version](https://badge.fury.io/rb/sensu-plugins-tripwire.svg)](http://badge.fury.io/rb/sensu-plugins-tripwire)
5
+ [![Code Climate](https://codeclimate.com/github/sensu-plugins/sensu-plugins-tripwire/badges/gpa.svg)](https://codeclimate.com/github/sensu-plugins/sensu-plugins-tripwire)
6
+ [![Test Coverage](https://codeclimate.com/github/sensu-plugins/sensu-plugins-tripwire/badges/coverage.svg)](https://codeclimate.com/github/sensu-plugins/sensu-plugins-tripwire)
7
+ [![Dependency Status](https://gemnasium.com/sensu-plugins/sensu-plugins-tripwire.svg)](https://gemnasium.com/sensu-plugins/sensu-plugins-tripwire)
8
+ [ ![Codeship Status for sensu-plugins/sensu-plugins-tripwire](https://codeship.com/projects/9cd33ec0-dc04-0132-3508-1e3fe125131b/status?branch=master)](https://codeship.com/projects/79859)
9
+
10
+ ## Functionality
11
+
12
+ ## Files
13
+ * bin/check-tripwire.rb
14
+
15
+ ## Usage
16
+
17
+ ## Installation
18
+
19
+ [Installation and Setup](https://github.com/sensu-plugins/documentation/blob/master/user_docs/installation_instructions.md)
20
+
21
+
22
+ ## Notes
@@ -0,0 +1,168 @@
1
+ #! /usr/bin/env ruby
2
+ #
3
+ # check-tripwire
4
+ #
5
+ # DESCRIPTION:
6
+ # This plugin periodically runs a check of the tripwire intrusion detection tool and
7
+ # posts events for each violation found.
8
+ #
9
+ # The plugin assumes that tripwire has been configured and that a tripwire database
10
+ # is available that contains the desired state of the system.
11
+ #
12
+ # The plugin does note require that the database be on the target machine. If an http
13
+ # url is supplied via the -d option then the database will be retrieved via http before
14
+ # the check is run and deleted afterward.
15
+ #
16
+ # OUTPUT:
17
+ # plain text
18
+ #
19
+ # PLATFORMS:
20
+ # Linux
21
+ #
22
+ # DEPENDENCIES:
23
+ # gem: sensu-plugin
24
+ # tripwire
25
+ #
26
+ # USAGE:
27
+ # there are sensible defaults for each of the options so the check can reasonably
28
+ # be run with no options. It is configurably for most modes of use though and the
29
+ # option descriptions below are fairly self explanatory.
30
+ #
31
+ # NOTES:
32
+ #
33
+ # LICENSE:
34
+ # Copyright 2013 Steve Gargan
35
+ # Released under the same terms as Sensu (the MIT license); see LICENSE
36
+ # for details.
37
+ #
38
+
39
+ require 'sensu-plugin/check/cli'
40
+ require 'json'
41
+ require 'open-uri'
42
+ require 'securerandom'
43
+
44
+ class TripwireCheck < Sensu::Plugin::Check::CLI
45
+ option :binary,
46
+ short: '-b path/to/tripwire',
47
+ long: '--binary path/to/tripwire',
48
+ description: 'tripwire binary to use, in case you hide yours',
49
+ required: false,
50
+ default: 'tripwire'
51
+
52
+ option :sitekey,
53
+ short: '-s path/to/sitekey',
54
+ long: '--site-key path/to/sitekey',
55
+ description: 'Site key used to decrypt the database that will be used in the validation',
56
+ required: false
57
+
58
+ option :password,
59
+ short: '-P PASSWORD',
60
+ long: '--password PASSWORD',
61
+ description: 'Password to unlock the keyfile',
62
+ required: false
63
+
64
+ option :database,
65
+ short: '-d path_or_url_to_database',
66
+ long: '--database path_or_url_to_database. if an http url is supplied the database will be retrieved prior to the check',
67
+ description: 'Database to use for the check',
68
+ required: false
69
+
70
+ option :critical,
71
+ short: '-c critical severity',
72
+ long: '--critical critical severity',
73
+ description: 'Tripwire severity greater than this is a critical error',
74
+ required: false,
75
+ default: '100'
76
+
77
+ option :warn,
78
+ short: '-w warn severity',
79
+ long: '--warn warining severity',
80
+ description: 'Tripwire severity greater than this is warning',
81
+ required: false,
82
+ default: '66'
83
+
84
+ def run_tripwire
85
+ site_key = (config[:sitekey] && "-S #{config[:sitekey]}") || ''
86
+ database = retrieve_database
87
+ database = (database && "-d #{database}") || ''
88
+ `#{config[:binary]} --check #{site_key} #{database}`
89
+ end
90
+
91
+ def retrieve_database
92
+ database = config[:database]
93
+
94
+ if database && database.start_with?('http')
95
+ id = SecureRandom.uuid
96
+ tmp_db = "./twd-#{id}"
97
+ begin
98
+ open(tmp_db, 'wb') do |db|
99
+ db << open(database).read
100
+ end
101
+ rescue => e
102
+ critical "Error loading database from #{database}. Message #{e.message}"
103
+ exit 1
104
+ end
105
+ database = tmp_db
106
+ end
107
+ database
108
+ end
109
+
110
+ def cleanup
111
+ Dir.glob('./twd-*') do |db|
112
+ File.delete(db)
113
+ end
114
+ end
115
+
116
+ def parse_violations(report)
117
+ rule_match = 'Rule Name: (.*)'
118
+ severity_level = 'Severity Level: (\d*)'
119
+ violation_type = '(Added|Modified|Removed).*'
120
+ quoted = '"([^"]*)"'
121
+
122
+ violations = {}
123
+ current_violation = nil
124
+ current_list = nil
125
+ report.each do |line|
126
+ if m = line.match(rule_match) # rubocop:disable AssignmentInCondition
127
+ name = m[1]
128
+ current_violation = { name: name }
129
+ violations[:name] = current_violation
130
+ end
131
+
132
+ if (m = line.match(severity_level))
133
+ current_violation[:level] = m[1].to_i
134
+ end
135
+
136
+ if (m = line.match(violation_type)) && current_violation # rubocop:disable AssignmentInCondition
137
+ current_list = []
138
+ current_violation[m[1]] = current_list
139
+ end
140
+
141
+ if (m = line.match(quoted)) && current_list
142
+ current_list << m[1]
143
+ end
144
+ end
145
+ violations
146
+ end
147
+
148
+ def run
149
+ begin
150
+ report = run_tripwire.split("\n")
151
+ violations = parse_violations report
152
+ cleanup
153
+ rescue => e
154
+ cleanup
155
+ warning "Error running tripwire. #{e. message}"
156
+ exit 1
157
+ end
158
+
159
+ violations.each do |_name, violation|
160
+ if violation[:level] >= config[:critical].to_i
161
+ critical violation.to_json
162
+ elsif violation[:level] >= config[:warn].to_i
163
+ warning violation.to_json
164
+ end
165
+ end
166
+ ok 'no violations' if violations.size == 0
167
+ end
168
+ end
@@ -0,0 +1,15 @@
1
+
2
+ require 'sensu-plugins-tripwire/version'
3
+
4
+ # Load the defaults
5
+
6
+ #
7
+ # Default class
8
+ #
9
+ module SensuPluginsTripwire
10
+ class << self
11
+ end
12
+
13
+ class << self
14
+ end
15
+ end
@@ -0,0 +1,28 @@
1
+ require 'json'
2
+
3
+ # encoding: utf-8
4
+ module SensuPluginsTripwire
5
+ # This defines the version of the gem
6
+ module Version
7
+ MAJOR = 0
8
+ MINOR = 0
9
+ PATCH = 1
10
+
11
+ VER_STRING = [MAJOR, MINOR, PATCH].compact.join('.')
12
+
13
+ NAME = 'sensu-plugins-tripwire'
14
+ BANNER = "#{NAME} v%s"
15
+
16
+ module_function
17
+
18
+ def version
19
+ format(BANNER, VER_STRING)
20
+ end
21
+
22
+ def json_version
23
+ {
24
+ 'version' => VER_STRING
25
+ }.to_json
26
+ end
27
+ end
28
+ end
metadata ADDED
@@ -0,0 +1,231 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: sensu-plugins-tripwire
3
+ version: !ruby/object:Gem::Version
4
+ version: 0.0.1
5
+ platform: ruby
6
+ authors:
7
+ - Sensu-Plugins and contributors
8
+ autorequire:
9
+ bindir: bin
10
+ cert_chain:
11
+ - |
12
+ -----BEGIN CERTIFICATE-----
13
+ MIIDgDCCAmigAwIBAgIBATANBgkqhkiG9w0BAQUFADBDMRIwEAYDVQQDDAltYXR0
14
+ am9uZXMxGDAWBgoJkiaJk/IsZAEZFgh5aWVsZGJvdDETMBEGCgmSJomT8ixkARkW
15
+ A2NvbTAeFw0xNTAxMjgyMTAyNTFaFw0xNjAxMjgyMTAyNTFaMEMxEjAQBgNVBAMM
16
+ CW1hdHRqb25lczEYMBYGCgmSJomT8ixkARkWCHlpZWxkYm90MRMwEQYKCZImiZPy
17
+ LGQBGRYDY29tMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAyTSzVYnO
18
+ CLgyrIyT1mBQakArQyW8xhi6MlDqyzXHJGeERT790U6EgoBVeS4XoK0ptFZNR8Tf
19
+ zko0w+Nv47TarSCgkPOaxY+mxWnAVR10dOmfeLr7huiMyps+YD56/EF2FqQ3jf/+
20
+ qohENfKD91qy1ieEy+Fn7Pf74ltbNKUdkb9a9eFXQ0DQ4ip5vik7DzjQkUTj4lca
21
+ k6ArwnmHX4YDhZoYtrQJ8jVktN0/+NtA40M5qkCYHNe5tUW25b/tKVYuioxG6b2Z
22
+ oIzaZxRLxf6HVAWpCVRT/F5+/yjigkX4u++eYacfLGleXQzoK7BL65vHGMJygWEE
23
+ 0TKGqFOrl/L0AQIDAQABo38wfTAJBgNVHRMEAjAAMAsGA1UdDwQEAwIEsDAdBgNV
24
+ HQ4EFgQUEf6a8Td7MrSZc8ImbLFZAENPbz0wIQYDVR0RBBowGIEWbWF0dGpvbmVz
25
+ QHlpZWxkYm90LmNvbTAhBgNVHRIEGjAYgRZtYXR0am9uZXNAeWllbGRib3QuY29t
26
+ MA0GCSqGSIb3DQEBBQUAA4IBAQBbzXAYA3BVGw8DZ0YYoY1VHPNEcH5qPIApmHO8
27
+ rvSmuUT0yMEi7u00H/5uHRFf4LleGT/+sTdyXKsNPGT9kdRuQEgwi+vf7Zfvd8aX
28
+ UF/+4VkEYf/8rV8Ere6u2QaWPgApdMV6JjKr1fAwCTd8AuGXNaWItiPPMseSQzLJ
29
+ JKP4hVvbc1d+oS925B1lcBiqn2aYvElbyNAVmQPywNNqkWmvtlqj9ZVJfV5HQLdu
30
+ 8sHuVruarogxxKPBzlL2is4EUb6oN/RdpGx2l4254+nyR+abg//Ed27Ym0PkB4lk
31
+ HP0m8WSjZmFr109pE/sVsM5jtOCvogyujQOjNVGN4gz1wwPr
32
+ -----END CERTIFICATE-----
33
+ date: 2015-05-21 00:00:00.000000000 Z
34
+ dependencies:
35
+ - !ruby/object:Gem::Dependency
36
+ name: sensu-plugin
37
+ requirement: !ruby/object:Gem::Requirement
38
+ requirements:
39
+ - - '='
40
+ - !ruby/object:Gem::Version
41
+ version: 1.1.0
42
+ type: :runtime
43
+ prerelease: false
44
+ version_requirements: !ruby/object:Gem::Requirement
45
+ requirements:
46
+ - - '='
47
+ - !ruby/object:Gem::Version
48
+ version: 1.1.0
49
+ - !ruby/object:Gem::Dependency
50
+ name: json
51
+ requirement: !ruby/object:Gem::Requirement
52
+ requirements:
53
+ - - '='
54
+ - !ruby/object:Gem::Version
55
+ version: 1.8.2
56
+ type: :runtime
57
+ prerelease: false
58
+ version_requirements: !ruby/object:Gem::Requirement
59
+ requirements:
60
+ - - '='
61
+ - !ruby/object:Gem::Version
62
+ version: 1.8.2
63
+ - !ruby/object:Gem::Dependency
64
+ name: codeclimate-test-reporter
65
+ requirement: !ruby/object:Gem::Requirement
66
+ requirements:
67
+ - - "~>"
68
+ - !ruby/object:Gem::Version
69
+ version: '0.4'
70
+ type: :development
71
+ prerelease: false
72
+ version_requirements: !ruby/object:Gem::Requirement
73
+ requirements:
74
+ - - "~>"
75
+ - !ruby/object:Gem::Version
76
+ version: '0.4'
77
+ - !ruby/object:Gem::Dependency
78
+ name: rubocop
79
+ requirement: !ruby/object:Gem::Requirement
80
+ requirements:
81
+ - - "~>"
82
+ - !ruby/object:Gem::Version
83
+ version: '0.30'
84
+ type: :development
85
+ prerelease: false
86
+ version_requirements: !ruby/object:Gem::Requirement
87
+ requirements:
88
+ - - "~>"
89
+ - !ruby/object:Gem::Version
90
+ version: '0.30'
91
+ - !ruby/object:Gem::Dependency
92
+ name: rspec
93
+ requirement: !ruby/object:Gem::Requirement
94
+ requirements:
95
+ - - "~>"
96
+ - !ruby/object:Gem::Version
97
+ version: '3.1'
98
+ type: :development
99
+ prerelease: false
100
+ version_requirements: !ruby/object:Gem::Requirement
101
+ requirements:
102
+ - - "~>"
103
+ - !ruby/object:Gem::Version
104
+ version: '3.1'
105
+ - !ruby/object:Gem::Dependency
106
+ name: bundler
107
+ requirement: !ruby/object:Gem::Requirement
108
+ requirements:
109
+ - - "~>"
110
+ - !ruby/object:Gem::Version
111
+ version: '1.7'
112
+ type: :development
113
+ prerelease: false
114
+ version_requirements: !ruby/object:Gem::Requirement
115
+ requirements:
116
+ - - "~>"
117
+ - !ruby/object:Gem::Version
118
+ version: '1.7'
119
+ - !ruby/object:Gem::Dependency
120
+ name: rake
121
+ requirement: !ruby/object:Gem::Requirement
122
+ requirements:
123
+ - - "~>"
124
+ - !ruby/object:Gem::Version
125
+ version: '10.0'
126
+ type: :development
127
+ prerelease: false
128
+ version_requirements: !ruby/object:Gem::Requirement
129
+ requirements:
130
+ - - "~>"
131
+ - !ruby/object:Gem::Version
132
+ version: '10.0'
133
+ - !ruby/object:Gem::Dependency
134
+ name: github-markup
135
+ requirement: !ruby/object:Gem::Requirement
136
+ requirements:
137
+ - - "~>"
138
+ - !ruby/object:Gem::Version
139
+ version: '1.3'
140
+ type: :development
141
+ prerelease: false
142
+ version_requirements: !ruby/object:Gem::Requirement
143
+ requirements:
144
+ - - "~>"
145
+ - !ruby/object:Gem::Version
146
+ version: '1.3'
147
+ - !ruby/object:Gem::Dependency
148
+ name: redcarpet
149
+ requirement: !ruby/object:Gem::Requirement
150
+ requirements:
151
+ - - "~>"
152
+ - !ruby/object:Gem::Version
153
+ version: '3.2'
154
+ type: :development
155
+ prerelease: false
156
+ version_requirements: !ruby/object:Gem::Requirement
157
+ requirements:
158
+ - - "~>"
159
+ - !ruby/object:Gem::Version
160
+ version: '3.2'
161
+ - !ruby/object:Gem::Dependency
162
+ name: yard
163
+ requirement: !ruby/object:Gem::Requirement
164
+ requirements:
165
+ - - "~>"
166
+ - !ruby/object:Gem::Version
167
+ version: '0.8'
168
+ type: :development
169
+ prerelease: false
170
+ version_requirements: !ruby/object:Gem::Requirement
171
+ requirements:
172
+ - - "~>"
173
+ - !ruby/object:Gem::Version
174
+ version: '0.8'
175
+ - !ruby/object:Gem::Dependency
176
+ name: pry
177
+ requirement: !ruby/object:Gem::Requirement
178
+ requirements:
179
+ - - "~>"
180
+ - !ruby/object:Gem::Version
181
+ version: '0.10'
182
+ type: :development
183
+ prerelease: false
184
+ version_requirements: !ruby/object:Gem::Requirement
185
+ requirements:
186
+ - - "~>"
187
+ - !ruby/object:Gem::Version
188
+ version: '0.10'
189
+ description: Sensu plugins for working with tripwire
190
+ email: "<sensu-users@googlegroups.com>"
191
+ executables: []
192
+ extensions: []
193
+ extra_rdoc_files: []
194
+ files:
195
+ - CHANGELOG.md
196
+ - LICENSE
197
+ - README.md
198
+ - bin/check-tripwire.rb
199
+ - lib/sensu-plugins-tripwire.rb
200
+ - lib/sensu-plugins-tripwire/version.rb
201
+ homepage: https://github.com/sensu-plugins/sensu-plugins-tripwire
202
+ licenses:
203
+ - MIT
204
+ metadata:
205
+ maintainer: ''
206
+ development_status: active
207
+ production_status: unstable - testing recommended
208
+ release_draft: 'false'
209
+ release_prerelease: 'false'
210
+ post_install_message: You can use the embedded Ruby by setting EMBEDDED_RUBY=true
211
+ in /etc/default/sensu
212
+ rdoc_options: []
213
+ require_paths:
214
+ - lib
215
+ required_ruby_version: !ruby/object:Gem::Requirement
216
+ requirements:
217
+ - - ">="
218
+ - !ruby/object:Gem::Version
219
+ version: 1.9.3
220
+ required_rubygems_version: !ruby/object:Gem::Requirement
221
+ requirements:
222
+ - - ">="
223
+ - !ruby/object:Gem::Version
224
+ version: '0'
225
+ requirements: []
226
+ rubyforge_project:
227
+ rubygems_version: 2.4.6
228
+ signing_key:
229
+ specification_version: 4
230
+ summary: Sensu plugins for working with tripwire
231
+ test_files: []
metadata.gz.sig ADDED
Binary file