airbrake 9.4.0 → 11.0.1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (50) hide show
  1. checksums.yaml +5 -5
  2. data/lib/airbrake.rb +2 -0
  3. data/lib/airbrake/capistrano.rb +2 -0
  4. data/lib/airbrake/capistrano/capistrano2.rb +2 -0
  5. data/lib/airbrake/capistrano/capistrano3.rb +3 -1
  6. data/lib/airbrake/delayed_job.rb +24 -6
  7. data/lib/airbrake/logger.rb +2 -0
  8. data/lib/airbrake/rack.rb +4 -0
  9. data/lib/airbrake/rack/context_filter.rb +9 -2
  10. data/lib/airbrake/rack/http_headers_filter.rb +7 -5
  11. data/lib/airbrake/rack/http_params_filter.rb +2 -0
  12. data/lib/airbrake/rack/instrumentable.rb +112 -4
  13. data/lib/airbrake/rack/middleware.rb +3 -1
  14. data/lib/airbrake/rack/request_body_filter.rb +2 -0
  15. data/lib/airbrake/rack/request_store.rb +2 -0
  16. data/lib/airbrake/rack/route_filter.rb +8 -10
  17. data/lib/airbrake/rack/session_filter.rb +2 -0
  18. data/lib/airbrake/rack/user.rb +9 -1
  19. data/lib/airbrake/rack/user_filter.rb +2 -0
  20. data/lib/airbrake/rails.rb +14 -135
  21. data/lib/airbrake/rails/action_cable.rb +2 -0
  22. data/lib/airbrake/rails/action_cable/notify_callback.rb +2 -0
  23. data/lib/airbrake/rails/action_controller.rb +9 -4
  24. data/lib/airbrake/rails/action_controller_notify_subscriber.rb +6 -2
  25. data/lib/airbrake/rails/action_controller_performance_breakdown_subscriber.rb +6 -1
  26. data/lib/airbrake/rails/action_controller_route_subscriber.rb +8 -15
  27. data/lib/airbrake/rails/active_job.rb +25 -8
  28. data/lib/airbrake/rails/active_record.rb +2 -0
  29. data/lib/airbrake/rails/active_record_subscriber.rb +7 -3
  30. data/lib/airbrake/rails/app.rb +64 -19
  31. data/lib/airbrake/rails/backtrace_cleaner.rb +13 -0
  32. data/lib/airbrake/rails/curb.rb +19 -22
  33. data/lib/airbrake/rails/event.rb +13 -7
  34. data/lib/airbrake/rails/excon_subscriber.rb +4 -0
  35. data/lib/airbrake/rails/http.rb +2 -0
  36. data/lib/airbrake/rails/http_client.rb +12 -6
  37. data/lib/airbrake/rails/net_http.rb +14 -6
  38. data/lib/airbrake/rails/railtie.rb +151 -0
  39. data/lib/airbrake/rails/typhoeus.rb +11 -7
  40. data/lib/airbrake/rake.rb +3 -1
  41. data/lib/airbrake/rake/tasks.rb +7 -5
  42. data/lib/airbrake/resque.rb +32 -0
  43. data/lib/airbrake/shoryuken.rb +17 -3
  44. data/lib/airbrake/sidekiq.rb +22 -14
  45. data/lib/airbrake/sidekiq/retryable_jobs_filter.rb +2 -0
  46. data/lib/airbrake/sneakers.rb +39 -1
  47. data/lib/airbrake/version.rb +3 -1
  48. data/lib/generators/airbrake_generator.rb +2 -0
  49. data/lib/generators/airbrake_initializer.rb.erb +6 -12
  50. metadata +62 -76
@@ -1,3 +1,5 @@
1
+ # frozen_string_literal: true
2
+
1
3
  module Airbrake
2
4
  module Sidekiq
3
5
  # Filter that can ignore notices from jobs that failed but will be retried
@@ -1,3 +1,5 @@
1
+ # frozen_string_literal: true
2
+
1
3
  module Airbrake
2
4
  module Sneakers
3
5
  # Provides integration with Sneakers.
@@ -10,17 +12,21 @@ module Airbrake
10
12
  # @see https://github.com/airbrake/airbrake/issues/850
11
13
  IGNORED_KEYS = %i[delivery_tag consumer channel].freeze
12
14
 
13
- def call(exception, worker = nil, **context)
15
+ # rubocop:disable Style/OptionalArguments
16
+ def call(exception, worker = nil, context)
17
+ # Later versions add a middle argument.
14
18
  Airbrake.notify(exception, filter_context(context)) do |notice|
15
19
  notice[:context][:component] = 'sneakers'
16
20
  notice[:context][:action] = worker.class.to_s
17
21
  end
18
22
  end
23
+ # rubocop:enable Style/OptionalArguments
19
24
 
20
25
  private
21
26
 
22
27
  def filter_context(context)
23
28
  return context unless context[:delivery_info]
29
+
24
30
  h = context.dup
25
31
  h[:delivery_info] = context[:delivery_info].reject do |k, _v|
26
32
  IGNORED_KEYS.include?(k)
@@ -32,3 +38,35 @@ module Airbrake
32
38
  end
33
39
 
34
40
  Sneakers.error_reporters << Airbrake::Sneakers::ErrorReporter.new
41
+
42
+ module Sneakers
43
+ # @todo Migrate to Sneakers v2.12.0 middleware API when it's released
44
+ # @see https://github.com/jondot/sneakers/pull/364
45
+ module Worker
46
+ # Sneakers v2.7.0+ renamed `do_work` to `process_work`.
47
+ if method_defined?(:process_work)
48
+ alias process_work_without_airbrake process_work
49
+ else
50
+ alias process_work_without_airbrake do_work
51
+ end
52
+
53
+ def process_work(delivery_info, metadata, msg, handler)
54
+ timing = Airbrake::Benchmark.measure do
55
+ process_work_without_airbrake(delivery_info, metadata, msg, handler)
56
+ end
57
+ rescue Exception => exception # rubocop:disable Lint/RescueException
58
+ Airbrake.notify_queue(
59
+ queue: self.class.to_s,
60
+ error_count: 1,
61
+ timing: 0.01,
62
+ )
63
+ raise exception
64
+ else
65
+ Airbrake.notify_queue(
66
+ queue: self.class.to_s,
67
+ error_count: 0,
68
+ timing: timing,
69
+ )
70
+ end
71
+ end
72
+ end
@@ -1,5 +1,7 @@
1
+ # frozen_string_literal: true
2
+
1
3
  # We use Semantic Versioning v2.0.0
2
4
  # More information: http://semver.org/
3
5
  module Airbrake
4
- AIRBRAKE_VERSION = '9.4.0'.freeze
6
+ AIRBRAKE_VERSION = '11.0.1'
5
7
  end
@@ -1,3 +1,5 @@
1
+ # frozen_string_literal: true
2
+
1
3
  # Creates the Airbrake initializer file for Rails apps.
2
4
  #
3
5
  # @example Invokation from terminal
@@ -1,3 +1,5 @@
1
+ # frozen_string_literal: true
2
+
1
3
  # Airbrake is an online tool that provides robust exception tracking in your Rails
2
4
  # applications. In doing so, it allows you to easily review errors, tie an error
3
5
  # to an individual piece of code, and trace the cause back to recent
@@ -33,15 +35,7 @@ Airbrake.configure do |c|
33
35
  # By default, Airbrake Ruby outputs to STDOUT. In Rails apps it makes sense to
34
36
  # use the Rails' logger.
35
37
  # https://github.com/airbrake/airbrake-ruby#logger
36
- c.logger =
37
- if ENV['RAILS_LOG_TO_STDOUT'].present?
38
- Logger.new(STDOUT, level: Rails.logger.level)
39
- else
40
- Logger.new(
41
- Rails.root.join('log', 'airbrake.log'),
42
- level: Rails.logger.level
43
- )
44
- end
38
+ c.logger = Airbrake::Rails.logger
45
39
 
46
40
  # Configures the environment the application is running in. Helps the Airbrake
47
41
  # dashboard to distinguish between exceptions occurring in different
@@ -60,12 +54,12 @@ Airbrake.configure do |c|
60
54
  # A list of parameters that should be filtered out of what is sent to
61
55
  # Airbrake. By default, all "password" attributes will have their contents
62
56
  # replaced.
63
- # https://github.com/airbrake/airbrake-ruby#blacklist_keys
64
- c.blacklist_keys = [/password/i, /authorization/i]
57
+ # https://github.com/airbrake/airbrake-ruby#blocklist_keys
58
+ c.blocklist_keys = [/password/i, /authorization/i]
65
59
 
66
60
  # Alternatively, you can integrate with Rails' filter_parameters.
67
61
  # Read more: https://goo.gl/gqQ1xS
68
- # c.blacklist_keys = Rails.application.config.filter_parameters
62
+ # c.blocklist_keys = Rails.application.config.filter_parameters
69
63
  end
70
64
 
71
65
  # A filter that collects request body information. Enable it if you are sure you
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: airbrake
3
3
  version: !ruby/object:Gem::Version
4
- version: 9.4.0
4
+ version: 11.0.1
5
5
  platform: ruby
6
6
  authors:
7
7
  - Airbrake Technologies, Inc.
8
- autorequire:
8
+ autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2019-07-29 00:00:00.000000000 Z
11
+ date: 2020-10-20 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: airbrake-ruby
@@ -16,14 +16,14 @@ dependencies:
16
16
  requirements:
17
17
  - - "~>"
18
18
  - !ruby/object:Gem::Version
19
- version: '4.5'
19
+ version: '5.1'
20
20
  type: :runtime
21
21
  prerelease: false
22
22
  version_requirements: !ruby/object:Gem::Requirement
23
23
  requirements:
24
24
  - - "~>"
25
25
  - !ruby/object:Gem::Version
26
- version: '4.5'
26
+ version: '5.1'
27
27
  - !ruby/object:Gem::Dependency
28
28
  name: rspec
29
29
  requirement: !ruby/object:Gem::Requirement
@@ -84,72 +84,72 @@ dependencies:
84
84
  name: appraisal
85
85
  requirement: !ruby/object:Gem::Requirement
86
86
  requirements:
87
- - - "~>"
87
+ - - ">="
88
88
  - !ruby/object:Gem::Version
89
- version: '2'
89
+ version: '0'
90
90
  type: :development
91
91
  prerelease: false
92
92
  version_requirements: !ruby/object:Gem::Requirement
93
93
  requirements:
94
- - - "~>"
94
+ - - ">="
95
95
  - !ruby/object:Gem::Version
96
- version: '2'
96
+ version: '0'
97
97
  - !ruby/object:Gem::Dependency
98
98
  name: rack
99
99
  requirement: !ruby/object:Gem::Requirement
100
100
  requirements:
101
101
  - - "~>"
102
102
  - !ruby/object:Gem::Version
103
- version: '1'
103
+ version: '2'
104
104
  type: :development
105
105
  prerelease: false
106
106
  version_requirements: !ruby/object:Gem::Requirement
107
107
  requirements:
108
108
  - - "~>"
109
109
  - !ruby/object:Gem::Version
110
- version: '1'
110
+ version: '2'
111
111
  - !ruby/object:Gem::Dependency
112
112
  name: webmock
113
113
  requirement: !ruby/object:Gem::Requirement
114
114
  requirements:
115
115
  - - "~>"
116
116
  - !ruby/object:Gem::Version
117
- version: '2'
117
+ version: '3'
118
118
  type: :development
119
119
  prerelease: false
120
120
  version_requirements: !ruby/object:Gem::Requirement
121
121
  requirements:
122
122
  - - "~>"
123
123
  - !ruby/object:Gem::Version
124
- version: '2'
124
+ version: '3'
125
125
  - !ruby/object:Gem::Dependency
126
- name: sneakers
126
+ name: amq-protocol
127
127
  requirement: !ruby/object:Gem::Requirement
128
128
  requirements:
129
- - - "~>"
129
+ - - ">="
130
130
  - !ruby/object:Gem::Version
131
- version: '2'
131
+ version: '0'
132
132
  type: :development
133
133
  prerelease: false
134
134
  version_requirements: !ruby/object:Gem::Requirement
135
135
  requirements:
136
- - - "~>"
136
+ - - ">="
137
137
  - !ruby/object:Gem::Version
138
- version: '2'
138
+ version: '0'
139
139
  - !ruby/object:Gem::Dependency
140
- name: amq-protocol
140
+ name: sneakers
141
141
  requirement: !ruby/object:Gem::Requirement
142
142
  requirements:
143
- - - '='
143
+ - - "~>"
144
144
  - !ruby/object:Gem::Version
145
- version: 2.2.0
145
+ version: '2'
146
146
  type: :development
147
147
  prerelease: false
148
148
  version_requirements: !ruby/object:Gem::Requirement
149
149
  requirements:
150
- - - '='
150
+ - - "~>"
151
151
  - !ruby/object:Gem::Version
152
- version: 2.2.0
152
+ version: '2'
153
153
  - !ruby/object:Gem::Dependency
154
154
  name: rack-test
155
155
  requirement: !ruby/object:Gem::Requirement
@@ -178,54 +178,6 @@ dependencies:
178
178
  - - '='
179
179
  - !ruby/object:Gem::Version
180
180
  version: 3.3.3
181
- - !ruby/object:Gem::Dependency
182
- name: public_suffix
183
- requirement: !ruby/object:Gem::Requirement
184
- requirements:
185
- - - "~>"
186
- - !ruby/object:Gem::Version
187
- version: '2.0'
188
- - - "<"
189
- - !ruby/object:Gem::Version
190
- version: '3.0'
191
- type: :development
192
- prerelease: false
193
- version_requirements: !ruby/object:Gem::Requirement
194
- requirements:
195
- - - "~>"
196
- - !ruby/object:Gem::Version
197
- version: '2.0'
198
- - - "<"
199
- - !ruby/object:Gem::Version
200
- version: '3.0'
201
- - !ruby/object:Gem::Dependency
202
- name: nokogiri
203
- requirement: !ruby/object:Gem::Requirement
204
- requirements:
205
- - - '='
206
- - !ruby/object:Gem::Version
207
- version: 1.9.1
208
- type: :development
209
- prerelease: false
210
- version_requirements: !ruby/object:Gem::Requirement
211
- requirements:
212
- - - '='
213
- - !ruby/object:Gem::Version
214
- version: 1.9.1
215
- - !ruby/object:Gem::Dependency
216
- name: parallel
217
- requirement: !ruby/object:Gem::Requirement
218
- requirements:
219
- - - '='
220
- - !ruby/object:Gem::Version
221
- version: 1.13.0
222
- type: :development
223
- prerelease: false
224
- version_requirements: !ruby/object:Gem::Requirement
225
- requirements:
226
- - - '='
227
- - !ruby/object:Gem::Version
228
- version: 1.13.0
229
181
  - !ruby/object:Gem::Dependency
230
182
  name: sidekiq
231
183
  requirement: !ruby/object:Gem::Requirement
@@ -310,6 +262,40 @@ dependencies:
310
262
  - - "~>"
311
263
  - !ruby/object:Gem::Version
312
264
  version: '1.3'
265
+ - !ruby/object:Gem::Dependency
266
+ name: public_suffix
267
+ requirement: !ruby/object:Gem::Requirement
268
+ requirements:
269
+ - - "~>"
270
+ - !ruby/object:Gem::Version
271
+ version: '2.0'
272
+ - - "<"
273
+ - !ruby/object:Gem::Version
274
+ version: '3.0'
275
+ type: :development
276
+ prerelease: false
277
+ version_requirements: !ruby/object:Gem::Requirement
278
+ requirements:
279
+ - - "~>"
280
+ - !ruby/object:Gem::Version
281
+ version: '2.0'
282
+ - - "<"
283
+ - !ruby/object:Gem::Version
284
+ version: '3.0'
285
+ - !ruby/object:Gem::Dependency
286
+ name: redis-namespace
287
+ requirement: !ruby/object:Gem::Requirement
288
+ requirements:
289
+ - - '='
290
+ - !ruby/object:Gem::Version
291
+ version: 1.6.0
292
+ type: :development
293
+ prerelease: false
294
+ version_requirements: !ruby/object:Gem::Requirement
295
+ requirements:
296
+ - - '='
297
+ - !ruby/object:Gem::Version
298
+ version: 1.6.0
313
299
  description: |
314
300
  Airbrake is an online tool that provides robust exception tracking in any of
315
301
  your Ruby applications. In doing so, it allows you to easily review errors, tie
@@ -362,6 +348,7 @@ files:
362
348
  - lib/airbrake/rails/http.rb
363
349
  - lib/airbrake/rails/http_client.rb
364
350
  - lib/airbrake/rails/net_http.rb
351
+ - lib/airbrake/rails/railtie.rb
365
352
  - lib/airbrake/rails/typhoeus.rb
366
353
  - lib/airbrake/rake.rb
367
354
  - lib/airbrake/rake/tasks.rb
@@ -377,7 +364,7 @@ homepage: https://airbrake.io
377
364
  licenses:
378
365
  - MIT
379
366
  metadata: {}
380
- post_install_message:
367
+ post_install_message:
381
368
  rdoc_options: []
382
369
  require_paths:
383
370
  - lib
@@ -385,16 +372,15 @@ required_ruby_version: !ruby/object:Gem::Requirement
385
372
  requirements:
386
373
  - - ">="
387
374
  - !ruby/object:Gem::Version
388
- version: '2.1'
375
+ version: '2.3'
389
376
  required_rubygems_version: !ruby/object:Gem::Requirement
390
377
  requirements:
391
378
  - - ">="
392
379
  - !ruby/object:Gem::Version
393
380
  version: '0'
394
381
  requirements: []
395
- rubyforge_project:
396
- rubygems_version: 2.6.14.4
397
- signing_key:
382
+ rubygems_version: 3.1.2
383
+ signing_key:
398
384
  specification_version: 4
399
385
  summary: Airbrake is an online tool that provides robust exception tracking in any
400
386
  of your Ruby applications.