Some checks failed
The Sentry setup used a config.sentry.* accessor that sentry-rails has never provided, so booting with SENTRY_DSN set raised NoMethodError during environment load (e.g. db:prepare). The code only ran once a DSN was configured, which is why it surfaced in production now. Rewrites config/initializers/sentry.rb to call Sentry.init, the actual sentry-ruby API, and removes the duplicate broken block from production.rb. Verified production boots with SENTRY_DSN set (Sentry.initialized? == true) and that the no-DSN path still early-returns. Co-Authored-By: Claude Opus 4.8 (1M context) <noreply@anthropic.com>
86 lines
2.7 KiB
Ruby
86 lines
2.7 KiB
Ruby
# Sentry configuration for error tracking and performance monitoring.
|
|
# Only initializes if the SENTRY_DSN environment variable is set.
|
|
|
|
return unless ENV["SENTRY_DSN"].present?
|
|
|
|
Sentry.init do |config|
|
|
config.dsn = ENV["SENTRY_DSN"]
|
|
|
|
# Environment label (defaults to Rails.env)
|
|
config.environment = ENV["SENTRY_ENVIRONMENT"] || Rails.env
|
|
|
|
# Release version from an env var or the current Git SHA
|
|
config.release = ENV["SENTRY_RELEASE"] || `git rev-parse HEAD 2>/dev/null`.strip.presence
|
|
|
|
# Only report from production unless explicitly enabled elsewhere.
|
|
config.enabled_environments =
|
|
if ENV["SENTRY_ENABLED_IN_DEVELOPMENT"] == "true"
|
|
%w[production development]
|
|
else
|
|
%w[production]
|
|
end
|
|
|
|
# Don't send cookies, request bodies, or user IPs by default.
|
|
config.send_default_pii = false
|
|
|
|
# Breadcrumbs for debugging
|
|
config.breadcrumbs_logger = [:active_support_logger, :http_logger]
|
|
|
|
# Performance monitoring sample rate (0.0 to 1.0)
|
|
config.traces_sample_rate = ENV.fetch("SENTRY_TRACES_SAMPLE_RATE", 0.1).to_f
|
|
|
|
# Profiling: disabled in production by default due to cost.
|
|
config.profiles_sample_rate =
|
|
if Rails.env.production?
|
|
ENV.fetch("SENTRY_PROFILES_SAMPLE_RATE", 0.0).to_f
|
|
else
|
|
ENV.fetch("SENTRY_PROFILES_SAMPLE_RATE", 0.5).to_f
|
|
end
|
|
|
|
# Ignore common non-critical exceptions
|
|
config.excluded_exceptions += [
|
|
"ActionController::RoutingError",
|
|
"ActionController::InvalidAuthenticityToken",
|
|
"ActionController::UnknownFormat",
|
|
"ActionDispatch::Http::Parameters::ParseError",
|
|
"Rack::QueryParser::InvalidParameterError",
|
|
"Rack::Timeout::RequestTimeoutException",
|
|
"ActiveRecord::RecordNotFound"
|
|
]
|
|
|
|
# Attach application/user context and scrub anything sensitive before sending.
|
|
config.before_send = lambda do |event, _hint|
|
|
event.tags = (event.tags || {}).merge(
|
|
app_name: "clinch",
|
|
app_environment: Rails.env
|
|
)
|
|
|
|
if defined?(Current) && Current.respond_to?(:user) && Current.user
|
|
event.user = (event.user || {}).merge(
|
|
id: Current.user.id,
|
|
email: Current.user.email_address,
|
|
admin: Current.user.admin?
|
|
)
|
|
end
|
|
|
|
if event.extra.is_a?(Hash)
|
|
event.extra.reject! do |key, value|
|
|
key.to_s.match?(/password|secret|token|key/i) || value.to_s.match?(/password|secret/i)
|
|
end
|
|
end
|
|
|
|
event
|
|
end
|
|
|
|
# Scrub sensitive data out of breadcrumbs.
|
|
config.before_breadcrumb = lambda do |breadcrumb, _hint|
|
|
if breadcrumb.data.is_a?(Hash)
|
|
breadcrumb.data.reject! do |key, value|
|
|
key.to_s.match?(/password|secret|token|key|authorization/i) || value.to_s.match?(/password|secret/i)
|
|
end
|
|
end
|
|
|
|
breadcrumb
|
|
end
|
|
end
|