Skip to content

Commit

Permalink
Revert "Migrate from sentry-raven to sentry-ruby" (dependabot#8874)
Browse files Browse the repository at this point in the history
  • Loading branch information
jakecoffman authored Jan 23, 2024
1 parent f6ae26c commit e693d3c
Show file tree
Hide file tree
Showing 24 changed files with 147 additions and 227 deletions.
2 changes: 1 addition & 1 deletion common/lib/dependabot/shared_helpers.rb
Original file line number Diff line number Diff line change
Expand Up @@ -112,7 +112,7 @@ def initialize(message:, error_context:, error_class: nil, trace: nil)
end

sig { returns(T::Hash[Symbol, T.untyped]) }
def sentry_context
def raven_context
{ fingerprint: [@fingerprint], extra: @error_context.except(:stderr_output, :fingerprint) }
end
end
Expand Down
2 changes: 1 addition & 1 deletion npm_and_yarn/lib/dependabot/npm_and_yarn/file_updater.rb
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,7 @@ def initialize(message:, error_context:)
@error_context = error_context
end

def sentry_context
def raven_context
{ extra: @error_context }
end
end
Expand Down
23 changes: 23 additions & 0 deletions sorbet/rbi/shims/sentry-raven.rbi
Original file line number Diff line number Diff line change
@@ -0,0 +1,23 @@
# typed: strong
# frozen_string_literal: true

module Raven
class << self
sig { params(_blk: T.proc.params(arg0: Raven::Configuration).void).void }
def configure(&_blk); end
end

class Configuration
sig { returns(T.nilable(::Logger)) }
attr_accessor :logger

sig { returns(T.nilable(String)) }
attr_accessor :project_root

sig { returns(T.nilable(::Regexp)) }
attr_accessor :app_dirs_pattern

sig { returns(T::Array[T.class_of(Raven::Processor)]) }
attr_accessor :processors
end
end
55 changes: 0 additions & 55 deletions sorbet/rbi/shims/sentry-ruby.rbi

This file was deleted.

2 changes: 2 additions & 0 deletions sorbet/rbi/todo.rbi
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,8 @@
# typed: false

module ::Azure::Error::NotFound; end
module ::Raven; end
class ::Raven::Processor; end
module Bundler::CompactIndexClient::Updater; end
module Bundler::SolveFailure; end
module Dependabot::NpmAndYarn::FileFetcher::Pysch::SyntaxError; end
Expand Down
2 changes: 1 addition & 1 deletion updater/Gemfile
Original file line number Diff line number Diff line change
Expand Up @@ -30,7 +30,7 @@ gem "opentelemetry-instrumentation-faraday", "~> 0.23"
gem "opentelemetry-instrumentation-http", "~> 0.23"
gem "opentelemetry-instrumentation-net_http", "~> 0.22"
gem "opentelemetry-sdk", "~> 1.3"
gem "sentry-ruby", "~> 5.1"
gem "sentry-raven", "~> 3.1"
gem "terminal-table", "~> 3.0.2"

group :test do
Expand Down
7 changes: 3 additions & 4 deletions updater/Gemfile.lock
Original file line number Diff line number Diff line change
Expand Up @@ -155,7 +155,6 @@ GEM
base64 (0.1.1)
citrus (3.0.2)
commonmarker (0.23.10)
concurrent-ruby (1.2.3)
crack (0.4.5)
rexml
debug (1.8.0)
Expand Down Expand Up @@ -322,8 +321,8 @@ GEM
sawyer (0.9.2)
addressable (>= 2.3.5)
faraday (>= 0.17.3, < 3)
sentry-ruby (5.16.1)
concurrent-ruby (~> 1.0, >= 1.0.2)
sentry-raven (3.1.2)
faraday (>= 1.0)
sorbet-runtime (0.5.11193)
stackprof (0.2.25)
stringio (3.0.8)
Expand Down Expand Up @@ -385,7 +384,7 @@ DEPENDENCIES
rubocop (~> 1.58.0)
rubocop-performance (~> 1.19.0)
rubocop-sorbet (~> 0.7.3)
sentry-ruby (~> 5.1)
sentry-raven (~> 3.1)
stackprof (~> 0.2.16)
terminal-table (~> 3.0.2)
turbo_tests (~> 2.2.0)
Expand Down
10 changes: 4 additions & 6 deletions updater/bin/fetch_files.rb
Original file line number Diff line number Diff line change
@@ -1,13 +1,11 @@
# typed: strict
# typed: false
# frozen_string_literal: true

require "sorbet-runtime"

$LOAD_PATH.unshift(T.must(__dir__) + "/../lib")
$LOAD_PATH.unshift(__dir__ + "/../lib")

$stdout.sync = true

require "sentry-ruby"
require "raven"
require "dependabot/setup"
require "dependabot/file_fetcher_command"
require "debug" if ENV["DEBUG"]
Expand All @@ -18,7 +16,7 @@ class UpdaterKilledError < StandardError; end
puts "Received SIGTERM"
error = UpdaterKilledError.new("Updater process killed with SIGTERM")
tags = { "gh.dependabot_api.update_job.id": ENV.fetch("DEPENDABOT_JOB_ID", nil) }
Sentry.capture_exception(error, tags: tags)
Raven.capture_exception(error, tags: tags)
exit
end

Expand Down
4 changes: 2 additions & 2 deletions updater/bin/update_files.rb
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@

$stdout.sync = true

require "sentry-ruby"
require "raven"
require "dependabot/setup"
require "dependabot/update_files_command"
require "debug" if ENV["DEBUG"]
Expand All @@ -16,7 +16,7 @@ class UpdaterKilledError < StandardError; end
puts "Received SIGTERM"
error = UpdaterKilledError.new("Updater process killed with SIGTERM")
tags = { "gh.dependabot_api.update_job.id": ENV.fetch("DEPENDABOT_JOB_ID", nil) }
Sentry.capture_exception(error, tags: tags)
Raven.capture_exception(error, tags: tags)
exit
end

Expand Down
1 change: 1 addition & 0 deletions updater/lib/dependabot/base_command.rb
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
# typed: true
# frozen_string_literal: true

require "raven"
require "dependabot/api_client"
require "dependabot/service"
require "dependabot/logger"
Expand Down
Original file line number Diff line number Diff line change
@@ -1,12 +1,11 @@
# typed: strong
# frozen_string_literal: true

require "sentry-ruby"
require "raven"
require "sorbet-runtime"
require "dependabot/sentry/processor"

# ExceptionSanitizer filters potential secrets/PII from exception payloads
class ExceptionSanitizer < ::Dependabot::Sentry::Processor
class ExceptionSanitizer < Raven::Processor
extend T::Sig

REPO = %r{[\w.\-]+/([\w.\-]+)}
Expand All @@ -19,24 +18,21 @@ class ExceptionSanitizer < ::Dependabot::Sentry::Processor
)

sig do
override
.params(
event: ::Sentry::Event,
_hint: T::Hash[Symbol, T.untyped]
)
.returns(::Sentry::Event)
params(data: T::Hash[Symbol, T.nilable(T::Hash[Symbol, T::Array[T::Hash[Symbol, String]]])])
.returns(T::Hash[Symbol, T.untyped])
end
def process(event, _hint)
return event unless event.is_a?(::Sentry::ErrorEvent)
def process(data)
return data unless data.dig(:exception, :values)

event.exception.values.each do |e|
T.must(data[:exception])[:values] = T.must(data.dig(:exception, :values)).map do |e|
PATTERNS.each do |key, regex|
e.value = e.value.gsub(regex) do |match|
e[:value] = T.must(e[:value]).gsub(regex) do |match|
match.sub(/#{T.must(Regexp.last_match).captures.compact.first}\z/, "[FILTERED_#{key.to_s.upcase}]")
end
end
e
end

event
data
end
end
35 changes: 0 additions & 35 deletions updater/lib/dependabot/sentry/processor.rb

This file was deleted.

25 changes: 0 additions & 25 deletions updater/lib/dependabot/sentry/sentry_context_processor.rb

This file was deleted.

33 changes: 17 additions & 16 deletions updater/lib/dependabot/service.rb
Original file line number Diff line number Diff line change
@@ -1,12 +1,11 @@
# typed: strict
# frozen_string_literal: true

require "sentry-ruby"
require "sorbet-runtime"
require "raven"
require "terminal-table"

require "dependabot/api_client"
require "dependabot/opentelemetry"
require "sorbet-runtime"

# This class provides an output adapter for the Dependabot Service which manages
# communication with the private API as well as consolidated error handling.
Expand Down Expand Up @@ -84,7 +83,7 @@ def update_dependency_list(dependency_snapshot:)
client.update_dependency_list(dependency_payload, dependency_file_paths)
end

# This method wraps the Sentry client as the Application error tracker
# This method wraps the Raven client as the Application error tracker
# the service uses to notice errors.
#
# This should be called as an alternative/in addition to record_update_job_error
Expand All @@ -101,19 +100,21 @@ def update_dependency_list(dependency_snapshot:)
end
def capture_exception(error:, job: nil, dependency: nil, dependency_group: nil, tags: {}, extra: {})
::Dependabot::OpenTelemetry.record_exception(error: error, job: job, tags: tags)
::Sentry.capture_exception(
T.unsafe(Raven).capture_exception(
error,
tags: tags.merge({
"gh.dependabot_api.update_job.id": job&.id,
"gh.dependabot_api.update_config.package_manager": job&.package_manager,
"gh.repo.is_private": job&.repo_private?
}.compact),
extra: extra.merge({
dependency_name: dependency&.name,
dependency_group: dependency_group&.name
}.compact),
user: {
id: job&.repo_owner
{
tags: tags.merge({
"gh.dependabot_api.update_job.id": job&.id,
"gh.dependabot_api.update_config.package_manager": job&.package_manager,
"gh.repo.is_private": job&.repo_private?
}.compact),
extra: extra.merge({
dependency_name: dependency&.name,
dependency_group: dependency_group&.name
}.compact),
user: {
id: job&.repo_owner
}
}
)
end
Expand Down
11 changes: 4 additions & 7 deletions updater/lib/dependabot/setup.rb
Original file line number Diff line number Diff line change
@@ -1,19 +1,17 @@
# typed: strict
# frozen_string_literal: true

require "sentry-ruby"

require "dependabot/environment"
require "dependabot/logger"
require "dependabot/logger/formats"
require "dependabot/sentry/processor"
require "dependabot/environment"

Dependabot.logger = Logger.new($stdout).tap do |logger|
logger.level = Dependabot::Environment.log_level
logger.formatter = Dependabot::Logger::BasicFormatter.new
end

Sentry.init do |config|
require "dependabot/sentry"
Raven.configure do |config|
config.logger = Dependabot.logger
config.project_root = File.expand_path("../../..", __dir__)

Expand Down Expand Up @@ -42,8 +40,7 @@
devcontainers
)}x

config.before_send = ->(event, hint) { Dependabot::Sentry::Processor.process_chain(event, hint) }
config.propagate_traces = false
config.processors += [ExceptionSanitizer]
end

require "dependabot/opentelemetry"
Expand Down
Loading

0 comments on commit e693d3c

Please sign in to comment.