33 lines
963 B
Ruby
33 lines
963 B
Ruby
|
###############
|
||
|
# One library to capture_exception and send to the specific service.
|
||
|
# # e as exception, u for user and a for account (user and account are optional)
|
||
|
# Usage: ChatwootExceptionTracker(e, user: u, account: a).capture_exception
|
||
|
############
|
||
|
|
||
|
class ChatwootExceptionTracker
|
||
|
def initialize(exception, user: nil, account: nil)
|
||
|
@exception = exception
|
||
|
@user = user
|
||
|
@account = account
|
||
|
end
|
||
|
|
||
|
def capture_exception
|
||
|
capture_exception_with_sentry if ENV['SENTRY_DSN'].present?
|
||
|
# Implement other providers like honeybadger, rollbar etc in future
|
||
|
end
|
||
|
|
||
|
private
|
||
|
|
||
|
def capture_exception_with_sentry
|
||
|
Sentry.with_scope do |scope|
|
||
|
if @account.present?
|
||
|
scope.set_context('account', { id: @account.id, name: @account.name })
|
||
|
scope.set_tags(account_id: @account.id)
|
||
|
end
|
||
|
|
||
|
scope.set_user(id: @user.id, email: @user.email) if @user.is_a?(User)
|
||
|
Sentry.capture_exception(@exception)
|
||
|
end
|
||
|
end
|
||
|
end
|