honeybadger 5.22.0 → 5.24.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/CHANGELOG.md +14 -0
- data/lib/honeybadger/agent.rb +5 -0
- data/lib/honeybadger/config/defaults.rb +25 -0
- data/lib/honeybadger/init/hanami.rb +1 -1
- data/lib/honeybadger/init/rails.rb +5 -3
- data/lib/honeybadger/plugins/active_job.rb +1 -1
- data/lib/honeybadger/plugins/autotuner.rb +9 -6
- data/lib/honeybadger/plugins/delayed_job.rb +1 -0
- data/lib/honeybadger/plugins/faktory.rb +1 -0
- data/lib/honeybadger/plugins/karafka.rb +5 -3
- data/lib/honeybadger/plugins/rails.rb +1 -1
- data/lib/honeybadger/plugins/resque.rb +1 -0
- data/lib/honeybadger/plugins/shoryuken.rb +1 -0
- data/lib/honeybadger/plugins/sidekiq.rb +43 -41
- data/lib/honeybadger/plugins/sucker_punch.rb +1 -0
- data/lib/honeybadger/plugins/thor.rb +1 -0
- data/lib/honeybadger/version.rb +1 -1
- data/lib/puma/plugin/honeybadger.rb +9 -3
- metadata +2 -2
    
        checksums.yaml
    CHANGED
    
    | @@ -1,7 +1,7 @@ | |
| 1 1 | 
             
            ---
         | 
| 2 2 | 
             
            SHA256:
         | 
| 3 | 
            -
              metadata.gz:  | 
| 4 | 
            -
              data.tar.gz:  | 
| 3 | 
            +
              metadata.gz: 31e329380be3a169c776198960e6557ca9868511737c1b272e9720dbe6f2740e
         | 
| 4 | 
            +
              data.tar.gz: 33347a45c58cd403e12cc3d93194163b6ee2ba310f54c04d5a9423221e4bc6f7
         | 
| 5 5 | 
             
            SHA512:
         | 
| 6 | 
            -
              metadata.gz:  | 
| 7 | 
            -
              data.tar.gz:  | 
| 6 | 
            +
              metadata.gz: 6c3b9297748ae34ff9bba398ae209de3917afa0d2f50569a697695702cac972e9212d13ea4d766be5eb90c257df8e3a0aac2688e200da2ea2c2f72f27809ac07
         | 
| 7 | 
            +
              data.tar.gz: 3f2a284a89f3a4ead20ac8dc75d537a0985dbe4aea60528571d528c3e54e4bf0e5e9f0bf57d8176ad926a794fa56a4e9a7c9663aa9291fec0d6cf1d4d902a75e
         | 
    
        data/CHANGELOG.md
    CHANGED
    
    | @@ -1,6 +1,20 @@ | |
| 1 1 | 
             
            # Change Log
         | 
| 2 2 |  | 
| 3 3 |  | 
| 4 | 
            +
            ## [5.24.0](https://github.com/honeybadger-io/honeybadger-ruby/compare/v5.23.0...v5.24.0) (2024-11-21)
         | 
| 5 | 
            +
             | 
| 6 | 
            +
             | 
| 7 | 
            +
            ### Features
         | 
| 8 | 
            +
             | 
| 9 | 
            +
            * skip middleware, plugins, and exception reporting when exceptions are disabled ([#646](https://github.com/honeybadger-io/honeybadger-ruby/issues/646)) ([6c4d7d5](https://github.com/honeybadger-io/honeybadger-ruby/commit/6c4d7d53f7356717894269b5fc9095621c9e8014))
         | 
| 10 | 
            +
             | 
| 11 | 
            +
            ## [5.23.0](https://github.com/honeybadger-io/honeybadger-ruby/compare/v5.22.0...v5.23.0) (2024-11-19)
         | 
| 12 | 
            +
             | 
| 13 | 
            +
             | 
| 14 | 
            +
            ### Features
         | 
| 15 | 
            +
             | 
| 16 | 
            +
            * update puma and autotuner plugins ([#644](https://github.com/honeybadger-io/honeybadger-ruby/issues/644)) ([1ed9687](https://github.com/honeybadger-io/honeybadger-ruby/commit/1ed96874c31c0273bc28cb917043f19140fd8204))
         | 
| 17 | 
            +
             | 
| 4 18 | 
             
            ## [5.22.0](https://github.com/honeybadger-io/honeybadger-ruby/compare/v5.21.0...v5.22.0) (2024-11-14)
         | 
| 5 19 |  | 
| 6 20 |  | 
    
        data/lib/honeybadger/agent.rb
    CHANGED
    
    | @@ -125,6 +125,11 @@ module Honeybadger | |
| 125 125 | 
             
                # @return [String] UUID reference to the notice within Honeybadger.
         | 
| 126 126 | 
             
                # @return [false] when ignored.
         | 
| 127 127 | 
             
                def notify(exception_or_opts = nil, opts = {}, **kwargs)
         | 
| 128 | 
            +
                  if !config[:'exceptions.enabled']
         | 
| 129 | 
            +
                    debug { 'disabled feature=notices' }
         | 
| 130 | 
            +
                    return false
         | 
| 131 | 
            +
                  end
         | 
| 132 | 
            +
             | 
| 128 133 | 
             
                  opts = opts.dup
         | 
| 129 134 | 
             
                  opts.merge!(kwargs)
         | 
| 130 135 |  | 
| @@ -491,6 +491,31 @@ module Honeybadger | |
| 491 491 | 
             
                    description: "Number of seconds between registry flushes.",
         | 
| 492 492 | 
             
                    default: 60,
         | 
| 493 493 | 
             
                    type: Integer
         | 
| 494 | 
            +
                  },
         | 
| 495 | 
            +
                  :'puma.insights.events' => {
         | 
| 496 | 
            +
                    description: 'Enable automatic event capturing for Puma stats.',
         | 
| 497 | 
            +
                    default: true,
         | 
| 498 | 
            +
                    type: Boolean
         | 
| 499 | 
            +
                  },
         | 
| 500 | 
            +
                  :'puma.insights.metrics' => {
         | 
| 501 | 
            +
                    description: 'Enable automatic metric data aggregation for Puma stats.',
         | 
| 502 | 
            +
                    default: false,
         | 
| 503 | 
            +
                    type: Boolean
         | 
| 504 | 
            +
                  },
         | 
| 505 | 
            +
                  :'puma.insights.collection_interval' => {
         | 
| 506 | 
            +
                    description: 'The frequency in which the Honeybadger gem will collect Puma stats.',
         | 
| 507 | 
            +
                    default: 1,
         | 
| 508 | 
            +
                    type: Integer
         | 
| 509 | 
            +
                  },
         | 
| 510 | 
            +
                  :'autotuner.insights.events' => {
         | 
| 511 | 
            +
                    description: 'Enable automatic event capturing for Autotuner stats.',
         | 
| 512 | 
            +
                    default: true,
         | 
| 513 | 
            +
                    type: Boolean
         | 
| 514 | 
            +
                  },
         | 
| 515 | 
            +
                  :'autotuner.insights.metrics' => {
         | 
| 516 | 
            +
                    description: 'Enable automatic metric data aggregation for Autotuner stats.',
         | 
| 517 | 
            +
                    default: false,
         | 
| 518 | 
            +
                    type: Boolean
         | 
| 494 519 | 
             
                  }
         | 
| 495 520 | 
             
                }.freeze
         | 
| 496 521 |  | 
| @@ -8,7 +8,7 @@ Honeybadger.init!({ | |
| 8 8 |  | 
| 9 9 | 
             
            Honeybadger.load_plugins!
         | 
| 10 10 |  | 
| 11 | 
            -
            if Hanami::VERSION >= '2.0'
         | 
| 11 | 
            +
            if Hanami::VERSION >= '2.0' && Honeybadger.config[:'exceptions.enabled']
         | 
| 12 12 | 
             
              Hanami.app.instance_eval do
         | 
| 13 13 | 
             
                config.middleware.use Honeybadger::Rack::UserFeedback
         | 
| 14 14 | 
             
                config.middleware.use Honeybadger::Rack::UserInformer
         | 
| @@ -14,9 +14,11 @@ module Honeybadger | |
| 14 14 | 
             
                    initializer 'honeybadger.install_middleware' do |app|
         | 
| 15 15 | 
             
                      honeybadger_config = Honeybadger::Agent.instance.config
         | 
| 16 16 |  | 
| 17 | 
            -
                       | 
| 18 | 
            -
             | 
| 19 | 
            -
             | 
| 17 | 
            +
                      if honeybadger_config[:'exceptions.enabled']
         | 
| 18 | 
            +
                        app.config.middleware.insert(0, Honeybadger::Rack::ErrorNotifier)
         | 
| 19 | 
            +
                        app.config.middleware.insert_before(Honeybadger::Rack::ErrorNotifier, Honeybadger::Rack::UserInformer) if honeybadger_config[:'user_informer.enabled']
         | 
| 20 | 
            +
                        app.config.middleware.insert_before(Honeybadger::Rack::ErrorNotifier, Honeybadger::Rack::UserFeedback) if honeybadger_config[:'feedback.enabled']
         | 
| 21 | 
            +
                      end
         | 
| 20 22 | 
             
                    end
         | 
| 21 23 |  | 
| 22 24 | 
             
                    config.before_initialize do
         | 
| @@ -51,7 +51,7 @@ module Honeybadger | |
| 51 51 | 
             
                    end
         | 
| 52 52 |  | 
| 53 53 | 
             
                    execution do
         | 
| 54 | 
            -
                      ::ActiveJob::Base.set_callback(:perform, :around, &ActiveJob.method(:perform_around))
         | 
| 54 | 
            +
                      ::ActiveJob::Base.set_callback(:perform, :around, &ActiveJob.method(:perform_around)) if Honeybadger.config[:'exceptions.enabled']
         | 
| 55 55 |  | 
| 56 56 | 
             
                      if config.load_plugin_insights?(:active_job)
         | 
| 57 57 | 
             
                        ::ActiveSupport::Notifications.subscribe(/(enqueue_at|enqueue|enqueue_retry|enqueue_all|perform|retry_stopped|discard)\.active_job/, Honeybadger::ActiveJobSubscriber.new)
         | 
| @@ -10,17 +10,20 @@ module Honeybadger | |
| 10 10 | 
             
                    execution do
         | 
| 11 11 | 
             
                      singleton_class.include(Honeybadger::InstrumentationHelper)
         | 
| 12 12 |  | 
| 13 | 
            -
                      ::Autotuner.enabled = true
         | 
| 14 | 
            -
             | 
| 15 13 | 
             
                      ::Autotuner.reporter = proc do |report|
         | 
| 16 14 | 
             
                        Honeybadger.event("report.autotuner", report: report.to_s)
         | 
| 17 15 | 
             
                      end
         | 
| 18 16 |  | 
| 19 | 
            -
                      metric_source 'autotuner'
         | 
| 20 | 
            -
             | 
| 21 17 | 
             
                      ::Autotuner.metrics_reporter = proc do |metrics|
         | 
| 22 | 
            -
                         | 
| 23 | 
            -
                           | 
| 18 | 
            +
                        if config.load_plugin_insights_events?(:autotuner)
         | 
| 19 | 
            +
                          Honeybadger.event('stats.autotuner', metrics)
         | 
| 20 | 
            +
                        end
         | 
| 21 | 
            +
             | 
| 22 | 
            +
                        if config.load_plugin_insights_metrics?(:autotuner)
         | 
| 23 | 
            +
                          metric_source 'autotuner'
         | 
| 24 | 
            +
                          metrics.each do |key, val|
         | 
| 25 | 
            +
                            gauge key, ->{ val }
         | 
| 26 | 
            +
                          end
         | 
| 24 27 | 
             
                        end
         | 
| 25 28 | 
             
                      end
         | 
| 26 29 | 
             
                    end
         | 
| @@ -8,9 +8,11 @@ module Honeybadger | |
| 8 8 | 
             
                  execution do
         | 
| 9 9 | 
             
                    require 'honeybadger/karafka'
         | 
| 10 10 |  | 
| 11 | 
            -
                     | 
| 12 | 
            -
             | 
| 13 | 
            -
             | 
| 11 | 
            +
                    if Honeybadger.config[:'exceptions.enabled']
         | 
| 12 | 
            +
                      errors_listener = ::Honeybadger::Karafka::ErrorsListener.new
         | 
| 13 | 
            +
                      ::Karafka.monitor.subscribe(errors_listener)
         | 
| 14 | 
            +
                      ::Karafka.producer.monitor.subscribe(errors_listener) if ::Karafka.respond_to?(:producer)
         | 
| 15 | 
            +
                    end
         | 
| 14 16 |  | 
| 15 17 | 
             
                    if config.load_plugin_insights?(:karafka)
         | 
| 16 18 | 
             
                      ::Karafka.monitor.subscribe(::Honeybadger::Karafka::InsightsListener.new)
         | 
| @@ -64,7 +64,7 @@ module Honeybadger | |
| 64 64 | 
             
                        ::ActionDispatch::ShowExceptions.prepend(ExceptionsCatcher)
         | 
| 65 65 | 
             
                      end
         | 
| 66 66 |  | 
| 67 | 
            -
                      if defined?(::ActiveSupport::ErrorReporter) # Rails 7
         | 
| 67 | 
            +
                      if Honeybadger.config[:'exceptions.enabled'] && defined?(::ActiveSupport::ErrorReporter) # Rails 7
         | 
| 68 68 | 
             
                        ::Rails.error.subscribe(ErrorSubscriber)
         | 
| 69 69 | 
             
                      end
         | 
| 70 70 | 
             
                    end
         | 
| @@ -73,60 +73,62 @@ module Honeybadger | |
| 73 73 | 
             
                    requirement { defined?(::Sidekiq) }
         | 
| 74 74 |  | 
| 75 75 | 
             
                    execution do
         | 
| 76 | 
            -
                       | 
| 77 | 
            -
                         | 
| 78 | 
            -
                           | 
| 76 | 
            +
                      if Honeybadger.config[:'exceptions.enabled']
         | 
| 77 | 
            +
                        ::Sidekiq.configure_server do |sidekiq|
         | 
| 78 | 
            +
                          sidekiq.server_middleware do |chain|
         | 
| 79 | 
            +
                            chain.prepend Middleware
         | 
| 80 | 
            +
                          end
         | 
| 79 81 | 
             
                        end
         | 
| 80 | 
            -
                      end
         | 
| 81 82 |  | 
| 82 | 
            -
             | 
| 83 | 
            -
             | 
| 83 | 
            +
                        if defined?(::Sidekiq::VERSION) && ::Sidekiq::VERSION > '3'
         | 
| 84 | 
            +
                          ::Sidekiq.configure_server do |sidekiq|
         | 
| 84 85 |  | 
| 85 | 
            -
             | 
| 86 | 
            -
             | 
| 86 | 
            +
                            sidekiq_default_configuration = (::Sidekiq::VERSION > '7') ?
         | 
| 87 | 
            +
                              ::Sidekiq.default_configuration : Class.new
         | 
| 87 88 |  | 
| 88 | 
            -
             | 
| 89 | 
            -
             | 
| 90 | 
            -
             | 
| 91 | 
            -
             | 
| 92 | 
            -
             | 
| 93 | 
            -
             | 
| 94 | 
            -
             | 
| 89 | 
            +
                            sidekiq.error_handlers << lambda { |ex, sidekiq_params, sidekiq_config = sidekiq_default_configuration|
         | 
| 90 | 
            +
                              params = sidekiq_params.dup
         | 
| 91 | 
            +
                              if defined?(::Sidekiq::Config)
         | 
| 92 | 
            +
                                if params[:_config].is_a?(::Sidekiq::Config) # Sidekiq > 6 and < 7.1.5
         | 
| 93 | 
            +
                                  params[:_config] = params[:_config].instance_variable_get(:@options)
         | 
| 94 | 
            +
                                else # Sidekiq >= 7.1.5
         | 
| 95 | 
            +
                                  params[:_config] = sidekiq_config.instance_variable_get(:@options)
         | 
| 96 | 
            +
                                end
         | 
| 95 97 | 
             
                              end
         | 
| 96 | 
            -
                            end
         | 
| 97 98 |  | 
| 98 | 
            -
             | 
| 99 | 
            +
                              job = params[:job] || params
         | 
| 99 100 |  | 
| 100 | 
            -
             | 
| 101 | 
            +
                              job_retry = job['retry'.freeze]
         | 
| 101 102 |  | 
| 102 | 
            -
             | 
| 103 | 
            -
             | 
| 104 | 
            -
             | 
| 105 | 
            -
             | 
| 106 | 
            -
             | 
| 107 | 
            -
             | 
| 108 | 
            -
             | 
| 109 | 
            -
             | 
| 103 | 
            +
                              if (threshold = config[:'sidekiq.attempt_threshold'].to_i) > 0 && job_retry
         | 
| 104 | 
            +
                                # We calculate the job attempts to determine the need to
         | 
| 105 | 
            +
                                # skip. Sidekiq's first job execution will have nil for the
         | 
| 106 | 
            +
                                # 'retry_count' job key. The first retry will have 0 set for
         | 
| 107 | 
            +
                                # the 'retry_count' key, incrementing on each execution
         | 
| 108 | 
            +
                                # afterwards.
         | 
| 109 | 
            +
                                retry_count = job['retry_count'.freeze]
         | 
| 110 | 
            +
                                attempt = retry_count ? retry_count + 1 : 0
         | 
| 110 111 |  | 
| 111 | 
            -
             | 
| 112 | 
            -
             | 
| 113 | 
            -
             | 
| 114 | 
            -
             | 
| 115 | 
            -
             | 
| 112 | 
            +
                                max_retries = (::Sidekiq::VERSION > '7') ?
         | 
| 113 | 
            +
                                  ::Sidekiq.default_configuration[:max_retries] : sidekiq.options[:max_retries]
         | 
| 114 | 
            +
                                # Ensure we account for modified max_retries setting
         | 
| 115 | 
            +
                                default_max_retry_attempts = defined?(::Sidekiq::JobRetry::DEFAULT_MAX_RETRY_ATTEMPTS) ? ::Sidekiq::JobRetry::DEFAULT_MAX_RETRY_ATTEMPTS : 25
         | 
| 116 | 
            +
                                retry_limit = job_retry == true ? (max_retries || default_max_retry_attempts) : job_retry.to_i
         | 
| 116 117 |  | 
| 117 | 
            -
             | 
| 118 | 
            +
                                limit = [retry_limit, threshold].min
         | 
| 118 119 |  | 
| 119 | 
            -
             | 
| 120 | 
            -
             | 
| 120 | 
            +
                                return if attempt < limit
         | 
| 121 | 
            +
                              end
         | 
| 121 122 |  | 
| 122 | 
            -
             | 
| 123 | 
            -
             | 
| 124 | 
            -
             | 
| 125 | 
            -
             | 
| 126 | 
            -
             | 
| 123 | 
            +
                              opts = { parameters: params }
         | 
| 124 | 
            +
                              if config[:'sidekiq.use_component']
         | 
| 125 | 
            +
                                opts[:component] = job['wrapped'.freeze] || job['class'.freeze]
         | 
| 126 | 
            +
                                opts[:action] = 'perform' if opts[:component]
         | 
| 127 | 
            +
                              end
         | 
| 127 128 |  | 
| 128 | 
            -
             | 
| 129 | 
            -
             | 
| 129 | 
            +
                              Honeybadger.notify(ex, opts)
         | 
| 130 | 
            +
                            }
         | 
| 131 | 
            +
                          end
         | 
| 130 132 | 
             
                        end
         | 
| 131 133 | 
             
                      end
         | 
| 132 134 |  | 
| @@ -6,6 +6,7 @@ module Honeybadger | |
| 6 6 | 
             
                requirement { defined?(::SuckerPunch) }
         | 
| 7 7 |  | 
| 8 8 | 
             
                execution do
         | 
| 9 | 
            +
                  return unless Honeybadger.config[:'exceptions.enabled']
         | 
| 9 10 | 
             
                  if SuckerPunch.respond_to?(:exception_handler=) # >= v2
         | 
| 10 11 | 
             
                    SuckerPunch.exception_handler = ->(ex, klass, args) { Honeybadger.notify(ex, { :component => klass, :parameters => args }) }
         | 
| 11 12 | 
             
                  else
         | 
    
        data/lib/honeybadger/version.rb
    CHANGED
    
    
| @@ -12,7 +12,7 @@ module Honeybadger | |
| 12 12 | 
             
                    in_background do
         | 
| 13 13 | 
             
                      loop do
         | 
| 14 14 | 
             
                        puma_plugin.record
         | 
| 15 | 
            -
                        sleep 1
         | 
| 15 | 
            +
                        sleep [::Honeybadger.config.collection_interval(:puma).to_i, 1].max
         | 
| 16 16 | 
             
                      end
         | 
| 17 17 | 
             
                    end
         | 
| 18 18 | 
             
                  end
         | 
| @@ -35,8 +35,14 @@ module Honeybadger | |
| 35 35 | 
             
                end
         | 
| 36 36 |  | 
| 37 37 | 
             
                def record_puma_stats(stats, context={})
         | 
| 38 | 
            -
                   | 
| 39 | 
            -
                     | 
| 38 | 
            +
                  if Honeybadger.config.load_plugin_insights_events?(:puma)
         | 
| 39 | 
            +
                    Honeybadger.event('stats.puma', context.merge(stats))
         | 
| 40 | 
            +
                  end
         | 
| 41 | 
            +
             | 
| 42 | 
            +
                  if Honeybadger.config.load_plugin_insights_metrics?(:puma)
         | 
| 43 | 
            +
                    STATS_KEYS.each do |stat|
         | 
| 44 | 
            +
                      gauge stat, context, ->{ stats[stat] } if stats[stat]
         | 
| 45 | 
            +
                    end
         | 
| 40 46 | 
             
                  end
         | 
| 41 47 | 
             
                end
         | 
| 42 48 | 
             
              end
         | 
    
        metadata
    CHANGED
    
    | @@ -1,14 +1,14 @@ | |
| 1 1 | 
             
            --- !ruby/object:Gem::Specification
         | 
| 2 2 | 
             
            name: honeybadger
         | 
| 3 3 | 
             
            version: !ruby/object:Gem::Version
         | 
| 4 | 
            -
              version: 5. | 
| 4 | 
            +
              version: 5.24.0
         | 
| 5 5 | 
             
            platform: ruby
         | 
| 6 6 | 
             
            authors:
         | 
| 7 7 | 
             
            - Honeybadger Industries LLC
         | 
| 8 8 | 
             
            autorequire: 
         | 
| 9 9 | 
             
            bindir: bin
         | 
| 10 10 | 
             
            cert_chain: []
         | 
| 11 | 
            -
            date: 2024-11- | 
| 11 | 
            +
            date: 2024-11-21 00:00:00.000000000 Z
         | 
| 12 12 | 
             
            dependencies:
         | 
| 13 13 | 
             
            - !ruby/object:Gem::Dependency
         | 
| 14 14 | 
             
              name: logger
         |