tcell_agent 2.1.2 → 2.2.0
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 +4 -4
- data/bin/tcell_agent +42 -146
- data/lib/tcell_agent.rb +8 -16
- data/lib/tcell_agent/agent.rb +76 -46
- data/lib/tcell_agent/config_initializer.rb +66 -0
- data/lib/tcell_agent/configuration.rb +72 -267
- data/lib/tcell_agent/instrument_servers.rb +14 -16
- data/lib/tcell_agent/instrumentation/monkey_patches/kernel.rb +1 -1
- data/lib/tcell_agent/logger.rb +1 -2
- data/lib/tcell_agent/rails/auth/authlogic.rb +46 -50
- data/lib/tcell_agent/rails/auth/authlogic_helper.rb +20 -0
- data/lib/tcell_agent/rails/auth/devise.rb +101 -103
- data/lib/tcell_agent/rails/auth/devise_helper.rb +29 -0
- data/lib/tcell_agent/rails/auth/doorkeeper.rb +55 -58
- data/lib/tcell_agent/{userinfo.rb → rails/auth/userinfo.rb} +0 -0
- data/lib/tcell_agent/rails/csrf_exception.rb +0 -8
- data/lib/tcell_agent/rails/dlp.rb +0 -4
- data/lib/tcell_agent/rails/middleware/global_middleware.rb +1 -1
- data/lib/tcell_agent/rails/{on_start.rb → railties/tcell_agent_railties.rb} +9 -16
- data/lib/tcell_agent/rails/railties/tcell_agent_unicorn_railties.rb +8 -0
- data/lib/tcell_agent/rails/routes.rb +3 -6
- data/lib/tcell_agent/rails/routes/grape.rb +1 -3
- data/lib/tcell_agent/rails/tcell_body_proxy.rb +0 -1
- data/lib/tcell_agent/rust/agent_config.rb +43 -32
- data/lib/tcell_agent/rust/{libtcellagent-4.18.0.dylib → libtcellagent-5.0.2.dylib} +0 -0
- data/lib/tcell_agent/rust/{libtcellagent-4.18.0.so → libtcellagent-5.0.2.so} +0 -0
- data/lib/tcell_agent/rust/{libtcellagent-alpine-4.18.0.so → libtcellagent-alpine-5.0.2.so} +0 -0
- data/lib/tcell_agent/rust/models.rb +9 -0
- data/lib/tcell_agent/rust/native_agent.rb +18 -0
- data/lib/tcell_agent/rust/native_library.rb +2 -1
- data/lib/tcell_agent/rust/{tcellagent-4.18.0.dll → tcellagent-5.0.2.dll} +0 -0
- data/lib/tcell_agent/servers/rails_server.rb +0 -1
- data/lib/tcell_agent/servers/unicorn.rb +1 -1
- data/lib/tcell_agent/servers/webrick.rb +0 -1
- data/lib/tcell_agent/settings_reporter.rb +0 -79
- data/lib/tcell_agent/version.rb +1 -1
- data/spec/lib/tcell_agent/configuration_spec.rb +56 -211
- data/spec/lib/tcell_agent/policies/patches_policy_spec.rb +2 -2
- data/spec/lib/tcell_agent/rust/agent_config_spec.rb +27 -0
- data/spec/lib/tcell_agent/settings_reporter_spec.rb +0 -73
- data/spec/support/builders.rb +5 -6
- metadata +14 -14
- data/lib/tcell_agent/authlogic.rb +0 -23
- data/lib/tcell_agent/config/unknown_options.rb +0 -119
- data/lib/tcell_agent/devise.rb +0 -33
- data/lib/tcell_agent/rails/start_agent_after_initializers.rb +0 -12
- data/spec/lib/tcell_agent/config/unknown_options_spec.rb +0 -195
Binary file
|
@@ -3,7 +3,7 @@ Unicorn::HttpServer.class_eval do
|
|
3
3
|
# - This check also ensures that a server is running as opposed to a different command such
|
4
4
|
# as `bundle exec rails runner User.count`.
|
5
5
|
unless Unicorn::HttpServer::START_CTX && Unicorn::HttpServer::START_CTX[0]
|
6
|
-
require 'tcell_agent/rails/
|
6
|
+
require 'tcell_agent/rails/railties/tcell_agent_unicorn_railties'
|
7
7
|
end
|
8
8
|
|
9
9
|
# This only gets instrumented when preload_app is true
|
@@ -37,85 +37,6 @@ module TCellAgent
|
|
37
37
|
)
|
38
38
|
end
|
39
39
|
|
40
|
-
TCellAgent::Instrumentation.safe_block('Instrumenting Initial Config') do
|
41
|
-
TCellAgent.send_event(
|
42
|
-
TCellAgent::SensorEvents::AgentSettingEvent.new(
|
43
|
-
'allow_payloads',
|
44
|
-
(!!TCellAgent.configuration.allow_payloads).to_s # rubocop:disable Style/DoubleNegation
|
45
|
-
)
|
46
|
-
)
|
47
|
-
|
48
|
-
TCellAgent.send_event(
|
49
|
-
TCellAgent::SensorEvents::AgentSettingEvent.new(
|
50
|
-
'reverse_proxy',
|
51
|
-
(!!TCellAgent.configuration.reverse_proxy).to_s # rubocop:disable Style/DoubleNegation
|
52
|
-
)
|
53
|
-
)
|
54
|
-
|
55
|
-
# Because of all the diff ways to initialize the agent
|
56
|
-
# some some of the following vars might not be set until
|
57
|
-
# we call this method, so call this method to set all
|
58
|
-
# the variables
|
59
|
-
TCellAgent.configuration.log_filename
|
60
|
-
|
61
|
-
TCellAgent.send_event(
|
62
|
-
TCellAgent::SensorEvents::AgentSettingEvent.new(
|
63
|
-
'config_filename',
|
64
|
-
TCellAgent.configuration.config_filename
|
65
|
-
)
|
66
|
-
)
|
67
|
-
TCellAgent.send_event(
|
68
|
-
TCellAgent::SensorEvents::AgentSettingEvent.new(
|
69
|
-
'logging_directory',
|
70
|
-
TCellAgent.configuration.agent_log_dir
|
71
|
-
)
|
72
|
-
)
|
73
|
-
|
74
|
-
TCellAgent.send_event(
|
75
|
-
TCellAgent::SensorEvents::AgentSettingEvent.new(
|
76
|
-
'agent_home_directory',
|
77
|
-
TCellAgent.configuration.agent_home_dir
|
78
|
-
)
|
79
|
-
)
|
80
|
-
|
81
|
-
logging_options = TCellAgent.configuration.logging_options || {}
|
82
|
-
use_default_setting = !logging_options.key?(:enabled) && !logging_options.key?('enabled')
|
83
|
-
if use_default_setting || logging_options[:enabled] || logging_options['enabled']
|
84
|
-
TCellAgent.send_event(
|
85
|
-
TCellAgent::SensorEvents::AgentSettingEvent.new('logging_enabled', 'true')
|
86
|
-
)
|
87
|
-
|
88
|
-
TCellAgent.send_event(
|
89
|
-
TCellAgent::SensorEvents::AgentSettingEvent.new(
|
90
|
-
'logging_level',
|
91
|
-
logging_options[:level] || logging_options['level'] || 'INFO'
|
92
|
-
)
|
93
|
-
)
|
94
|
-
else
|
95
|
-
TCellAgent.send_event(
|
96
|
-
TCellAgent::SensorEvents::AgentSettingEvent.new('logging_enabled', 'false')
|
97
|
-
)
|
98
|
-
end
|
99
|
-
|
100
|
-
if TCellAgent.configuration.hmac_key
|
101
|
-
TCellAgent.send_event(
|
102
|
-
TCellAgent::SensorEvents::AgentSettingEvent.new(
|
103
|
-
'hmac_key_present',
|
104
|
-
(!!TCellAgent.configuration.hmac_key).to_s # rubocop:disable Style/DoubleNegation
|
105
|
-
)
|
106
|
-
)
|
107
|
-
end
|
108
|
-
|
109
|
-
if TCellAgent.configuration.reverse_proxy
|
110
|
-
TCellAgent.send_event(
|
111
|
-
TCellAgent::SensorEvents::AgentSettingEvent.new(
|
112
|
-
'reverse_proxy_ip_address_header',
|
113
|
-
TCellAgent.configuration.reverse_proxy_ip_address_header
|
114
|
-
)
|
115
|
-
)
|
116
|
-
end
|
117
|
-
end
|
118
|
-
|
119
40
|
if defined?(::Rails)
|
120
41
|
TCellAgent::Instrumentation.safe_block('Instrumenting routes') do
|
121
42
|
TCellAgent::Instrumentation::Rails.instrument_routes
|
data/lib/tcell_agent/version.rb
CHANGED
@@ -2,228 +2,73 @@ require 'spec_helper'
|
|
2
2
|
|
3
3
|
module TCellAgent
|
4
4
|
describe Configuration do
|
5
|
-
describe '
|
6
|
-
context '
|
7
|
-
it 'should
|
8
|
-
|
5
|
+
describe 'should_instrument?' do
|
6
|
+
context 'with the agent disabled' do
|
7
|
+
it 'should return false' do
|
8
|
+
config = Configuration.new
|
9
|
+
config.enabled = false
|
9
10
|
|
10
|
-
expect(
|
11
|
-
File.join(Dir.getwd, 'tcell/logs/tcell_agent.log')
|
12
|
-
)
|
13
|
-
expect(configuration.config_filename).to eq(
|
14
|
-
File.join(Dir.getwd, 'config/tcell_agent.config')
|
15
|
-
)
|
11
|
+
expect(config.should_instrument?).to be_falsey
|
16
12
|
end
|
17
13
|
end
|
14
|
+
context 'with the agent enabled' do
|
15
|
+
context 'with all instrumentation enabled' do
|
16
|
+
context 'with no parameters' do
|
17
|
+
it 'should return true' do
|
18
|
+
config = Configuration.new
|
19
|
+
|
20
|
+
expect(config.should_instrument?).to be_truthy
|
21
|
+
end
|
22
|
+
end
|
23
|
+
context 'with parameters' do
|
24
|
+
it 'should return true' do
|
25
|
+
config = Configuration.new
|
18
26
|
|
19
|
-
|
20
|
-
|
21
|
-
|
22
|
-
|
23
|
-
ENV['TCELL_AGENT_HOME'] = 'spec_tcell_home'
|
24
|
-
|
25
|
-
configuration = Configuration.new
|
26
|
-
|
27
|
-
expect(configuration.log_filename).to eq(
|
28
|
-
'spec_tcell_home/logs/tcell_agent.log'
|
29
|
-
)
|
30
|
-
expect(configuration.config_filename).to eq(
|
31
|
-
File.join(Dir.getwd, 'config/tcell_agent.config')
|
32
|
-
)
|
33
|
-
|
34
|
-
ENV['TCELL_AGENT_HOME'] = old_tcell_agent_home
|
35
|
-
end
|
36
|
-
end
|
37
|
-
|
38
|
-
context 'TCELL_AGENT_HOME and TCELL_AGENT_LOG_DIR defined' do
|
39
|
-
it 'should set config filename to default, cache file and log file are updated' do
|
40
|
-
old_tcell_agent_home = ENV['TCELL_AGENT_HOME']
|
41
|
-
old_tcell_agent_log_dir = ENV['TCELL_AGENT_LOG_DIR']
|
42
|
-
|
43
|
-
ENV['TCELL_AGENT_HOME'] = 'spec_tcell_home'
|
44
|
-
ENV['TCELL_AGENT_LOG_DIR'] = 'spec_tcell_log_dir'
|
45
|
-
|
46
|
-
configuration = Configuration.new
|
47
|
-
|
48
|
-
expect(configuration.log_filename).to eq(
|
49
|
-
'spec_tcell_log_dir/tcell_agent.log'
|
50
|
-
)
|
51
|
-
expect(configuration.config_filename).to eq(
|
52
|
-
File.join(Dir.getwd, 'config/tcell_agent.config')
|
53
|
-
)
|
54
|
-
|
55
|
-
ENV['TCELL_AGENT_HOME'] = old_tcell_agent_home
|
56
|
-
ENV['TCELL_AGENT_LOG_DIR'] = old_tcell_agent_log_dir
|
57
|
-
end
|
58
|
-
end
|
59
|
-
|
60
|
-
context 'TCELL_AGENT_HOME, TCELL_AGENT_LOG_DIR, and TCELL_AGENT_CONFIG defined ' do
|
61
|
-
it 'should update config filename, cache file, and log file' do
|
62
|
-
old_tcell_agent_home = ENV['TCELL_AGENT_HOME']
|
63
|
-
old_tcell_agent_log_dir = ENV['TCELL_AGENT_LOG_DIR']
|
64
|
-
old_config_filename = ENV['TCELL_AGENT_CONFIG']
|
65
|
-
|
66
|
-
ENV['TCELL_AGENT_HOME'] = 'spec_tcell_home'
|
67
|
-
ENV['TCELL_AGENT_LOG_DIR'] = 'spec_tcell_log_dir'
|
68
|
-
ENV['TCELL_AGENT_CONFIG'] = 'spec_config/tcell_agent.config'
|
69
|
-
|
70
|
-
configuration = Configuration.new
|
71
|
-
|
72
|
-
expect(configuration.log_filename).to eq(
|
73
|
-
'spec_tcell_log_dir/tcell_agent.log'
|
74
|
-
)
|
75
|
-
expect(configuration.config_filename).to eq(
|
76
|
-
'spec_config/tcell_agent.config'
|
77
|
-
)
|
78
|
-
|
79
|
-
ENV['TCELL_AGENT_HOME'] = old_tcell_agent_home
|
80
|
-
ENV['TCELL_AGENT_LOG_DIR'] = old_tcell_agent_log_dir
|
81
|
-
ENV['TCELL_AGENT_CONFIG'] = old_config_filename
|
82
|
-
end
|
83
|
-
end
|
84
|
-
end
|
85
|
-
|
86
|
-
describe '#data_exposure' do
|
87
|
-
context 'no data_exposure defined' do
|
88
|
-
it 'should set max_data_ex_db_records_per_request to default' do
|
89
|
-
no_data_ex = double(
|
90
|
-
'no_data_ex',
|
91
|
-
:read => {
|
92
|
-
:version => 1,
|
93
|
-
:applications => [
|
94
|
-
:app_id => 'app_id',
|
95
|
-
:name => 'test',
|
96
|
-
:api_key => 'api_key'
|
97
|
-
]
|
98
|
-
}.to_json
|
99
|
-
)
|
100
|
-
expect(File).to receive(:file?).with(
|
101
|
-
File.join(Dir.getwd, 'no_data_ex.config')
|
102
|
-
).and_return(true)
|
103
|
-
expect(File).to receive(:open).with(
|
104
|
-
File.join(Dir.getwd, 'no_data_ex.config')
|
105
|
-
).and_return(no_data_ex)
|
106
|
-
configuration = Configuration.new('no_data_ex.config')
|
107
|
-
|
108
|
-
expect(configuration.max_data_ex_db_records_per_request).to eq(1000)
|
109
|
-
end
|
110
|
-
end
|
111
|
-
|
112
|
-
context 'data_exposure is empty' do
|
113
|
-
it 'should set max_data_ex_db_records_per_request to default' do
|
114
|
-
no_data_ex = double(
|
115
|
-
'no_data_ex',
|
116
|
-
:read => {
|
117
|
-
:version => 1,
|
118
|
-
:applications => [
|
119
|
-
:app_id => 'app_id',
|
120
|
-
:name => 'test',
|
121
|
-
:api_key => 'api_key',
|
122
|
-
:data_exposure => {}
|
123
|
-
]
|
124
|
-
}.to_json
|
125
|
-
)
|
126
|
-
expect(File).to receive(:file?).with(
|
127
|
-
File.join(Dir.getwd, 'no_data_ex.config')
|
128
|
-
).and_return(true)
|
129
|
-
expect(File).to receive(:open).with(
|
130
|
-
File.join(Dir.getwd, 'no_data_ex.config')
|
131
|
-
).and_return(no_data_ex)
|
132
|
-
configuration = Configuration.new('no_data_ex.config')
|
133
|
-
|
134
|
-
expect(configuration.max_data_ex_db_records_per_request).to eq(1000)
|
27
|
+
expect(config.should_instrument?('devise')).to be_truthy
|
28
|
+
end
|
29
|
+
end
|
135
30
|
end
|
136
|
-
|
137
|
-
|
138
|
-
|
139
|
-
|
140
|
-
no_data_ex = double(
|
141
|
-
'no_data_ex',
|
142
|
-
:read => {
|
143
|
-
:version => 1,
|
144
|
-
:applications => [
|
145
|
-
:app_id => 'app_id',
|
146
|
-
:name => 'test',
|
147
|
-
:api_key => 'api_key',
|
148
|
-
:data_exposure => {
|
149
|
-
:max_data_ex_db_records_per_request => 5000
|
150
|
-
}
|
151
|
-
]
|
152
|
-
}.to_json
|
153
|
-
)
|
154
|
-
expect(File).to receive(:file?).with(
|
155
|
-
File.join(Dir.getwd, 'no_data_ex.config')
|
156
|
-
).and_return(true)
|
157
|
-
expect(File).to receive(:open).with(
|
158
|
-
File.join(Dir.getwd, 'no_data_ex.config')
|
159
|
-
).and_return(no_data_ex)
|
160
|
-
configuration = Configuration.new('no_data_ex.config')
|
31
|
+
context 'with auth frameworks disabled' do
|
32
|
+
it 'should return false' do
|
33
|
+
config = Configuration.new
|
34
|
+
config.disabled_instrumentation = Set.new(%w[authlogic devise doorkeeper])
|
161
35
|
|
162
|
-
|
36
|
+
expect(config.should_instrument?('devise')).to be_falsey
|
37
|
+
end
|
163
38
|
end
|
164
39
|
end
|
165
40
|
end
|
166
|
-
|
167
|
-
|
168
|
-
|
169
|
-
|
170
|
-
|
171
|
-
|
172
|
-
|
173
|
-
|
174
|
-
|
175
|
-
:applications => [
|
176
|
-
:app_id => 'app_id',
|
177
|
-
:api_key => 'api_key',
|
178
|
-
:allow_payloads => false
|
179
|
-
]
|
180
|
-
}.to_json
|
181
|
-
)
|
182
|
-
expect(File).to receive(:file?).with(
|
183
|
-
File.join(Dir.getwd, 'config/tcell_agent.config')
|
184
|
-
).and_return(true)
|
185
|
-
expect(File).to receive(:open).with(
|
186
|
-
File.join(Dir.getwd, 'config/tcell_agent.config')
|
187
|
-
).and_return(allow_payloads_enabled)
|
188
|
-
|
189
|
-
configuration = Configuration.new
|
190
|
-
|
191
|
-
expect(configuration.allow_payloads).to eq(false)
|
192
|
-
end
|
41
|
+
describe 'populate_configuration' do
|
42
|
+
context 'with a poor native_agent_config_response' do
|
43
|
+
it 'should not throw an error' do
|
44
|
+
native_agent_config_response = {}
|
45
|
+
|
46
|
+
config = Configuration.new
|
47
|
+
expect do
|
48
|
+
config.populate_configuration(native_agent_config_response)
|
49
|
+
end.not_to raise_error
|
193
50
|
end
|
194
51
|
end
|
195
|
-
|
196
|
-
|
197
|
-
|
198
|
-
|
199
|
-
|
200
|
-
|
201
|
-
|
202
|
-
|
203
|
-
|
204
|
-
|
205
|
-
|
206
|
-
|
207
|
-
|
208
|
-
|
209
|
-
|
210
|
-
|
211
|
-
|
212
|
-
|
213
|
-
|
214
|
-
|
215
|
-
File.join(Dir.getwd, 'config/tcell_agent.config')
|
216
|
-
).and_return(true)
|
217
|
-
expect(File).to receive(:open).with(
|
218
|
-
File.join(Dir.getwd, 'config/tcell_agent.config')
|
219
|
-
).and_return(allow_payloads_enabled)
|
220
|
-
|
221
|
-
configuration = Configuration.new
|
222
|
-
|
223
|
-
ENV['TCELL_AGENT_ALLOW_PAYLOADS'] = old_tcell_agent_allow_payloads
|
224
|
-
|
225
|
-
expect(configuration.allow_payloads).to eq(false)
|
226
|
-
end
|
52
|
+
context 'with an elaborate native_agent_config_response' do
|
53
|
+
it 'should set all the correct configurations' do
|
54
|
+
native_agent_config_response = { 'enabled' => true,
|
55
|
+
'disabled_instrumentation' => %w[devise doorkeeper],
|
56
|
+
'update_policy' => 'true',
|
57
|
+
'applications' => { 'first' => { 'app_id' => 'app_id_placeholder',
|
58
|
+
'api_key' => 'api_key_paceholder',
|
59
|
+
'hmac_key' => 'hmac_key_placeholder',
|
60
|
+
'password_hmac_key' => 'password_hmac_key_placeholder',
|
61
|
+
'proxy_config' => { 'reverse_proxy' => true,
|
62
|
+
'reverse_proxy_ip_address_header' => 'X-Forwarded-For' } } },
|
63
|
+
'endpoint_config' => { 'api_url' => 'https://us.agent.tcell.insight.rapid7.com/api/v1' },
|
64
|
+
'ruby_config' => { 'enable_policy_polling' => true } }
|
65
|
+
|
66
|
+
config = Configuration.new
|
67
|
+
config.populate_configuration(native_agent_config_response)
|
68
|
+
|
69
|
+
expect(config.disabled_instrumentation).to be_a(Set)
|
70
|
+
expect(config.disabled_instrumentation).to include('devise', 'doorkeeper')
|
71
|
+
expect(config.enable_intercept_requests).to be_truthy
|
227
72
|
end
|
228
73
|
end
|
229
74
|
end
|
@@ -73,7 +73,7 @@ module TCellAgent
|
|
73
73
|
TCellAgent::Rust::NativeAgent.free_agent(@native_agent.agent_ptr)
|
74
74
|
end
|
75
75
|
|
76
|
-
context 'request has nil ip' do
|
76
|
+
context 'request has nil ip', :skip => true do
|
77
77
|
it 'should not block request' do
|
78
78
|
meta_data = TCellAgent::Tests::MetaDataBuilder.new.update_attribute(
|
79
79
|
'remote_address', nil
|
@@ -83,7 +83,7 @@ module TCellAgent
|
|
83
83
|
end
|
84
84
|
end
|
85
85
|
|
86
|
-
context 'request has empty ip' do
|
86
|
+
context 'request has empty ip', :skip => true do
|
87
87
|
it 'should not block request' do
|
88
88
|
meta_data = TCellAgent::Tests::MetaDataBuilder.new.update_attribute(
|
89
89
|
'remote_address', ''
|
@@ -0,0 +1,27 @@
|
|
1
|
+
require 'spec_helper'
|
2
|
+
|
3
|
+
module TCellAgent
|
4
|
+
module Rust
|
5
|
+
describe AgentConfig do
|
6
|
+
context 'with initializers set' do
|
7
|
+
before do
|
8
|
+
TCellAgent.configure do |config|
|
9
|
+
config.app_id = 'initializer_app_id_set'
|
10
|
+
config.api_key = 'initializer_api_key_set'
|
11
|
+
config.enabled_instrumentations = { 'authlogic' => false, :devise => false, 'doorkeeper' => false }
|
12
|
+
config.hmac_key = config.app_id
|
13
|
+
end
|
14
|
+
end
|
15
|
+
it 'should return the correct values' do
|
16
|
+
config = AgentConfig.new(TCellAgent.initializer_configuration)
|
17
|
+
|
18
|
+
expect(config['agent_type']).to eq 'Ruby'
|
19
|
+
expect(config['overrides']['disabled_instrumentation']).to contain_exactly('authlogic', 'devise', 'doorkeeper')
|
20
|
+
expect(config['overrides']['applications'][0][:api_key]).to eq 'initializer_api_key_set'
|
21
|
+
expect(config['overrides']['applications'][0][:app_id]).to eq 'initializer_app_id_set'
|
22
|
+
expect(config['overrides']['applications'][0][:api_key]).to eq 'initializer_api_key_set'
|
23
|
+
end
|
24
|
+
end
|
25
|
+
end
|
26
|
+
end
|
27
|
+
end
|