2019-08-14 09:48:44 +00:00
|
|
|
Raven.configure do |config|
|
|
|
|
config.dsn = ENV['SENTRY_DSN']
|
2019-10-20 08:47:26 +00:00
|
|
|
config.environments = %w[staging production]
|
2019-08-14 09:48:44 +00:00
|
|
|
end
|
|
|
|
|
|
|
|
module QueryTrace
|
|
|
|
def self.enable!
|
|
|
|
::ActiveRecord::LogSubscriber.send(:include, self)
|
|
|
|
end
|
|
|
|
|
|
|
|
def self.append_features(klass)
|
|
|
|
super
|
|
|
|
klass.class_eval do
|
|
|
|
unless method_defined?(:log_info_without_trace)
|
|
|
|
alias_method :log_info_without_trace, :sql
|
|
|
|
alias_method :sql, :log_info_with_trace
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def log_info_with_trace(event)
|
|
|
|
log_info_without_trace(event)
|
|
|
|
trace_log = Rails.backtrace_cleaner.clean(caller).first
|
2020-09-08 05:54:08 +00:00
|
|
|
logger.debug(" \\_ \e[33mCalled from:\e[0m #{trace_log}") if trace_log && event.payload[:name] != 'SCHEMA'
|
2019-08-14 09:48:44 +00:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
QueryTrace.enable! unless Rails.env.production?
|