Sha256: a083fca8e18c970d46f0716ab58b79b9abbdafe6bc4361db9c5656d617c4d620
Contents?: true
Size: 1.79 KB
Versions: 1
Compression:
Stored size: 1.79 KB
Contents
module Nadir class Notification def initialize(exception, params = {}) @exception = exception @params = params end def to_params { class: @exception.class.name, message: @exception.message, location: location, backtrace: backtrace.join("\n"), environment: Nadir.config.env, timestamp: Time.current, fingerprint: fingerprint, host: Socket.gethostname, pid: Process.pid, request_params: @params.dig(:request, :params), request_remote_ip: @params.dig(:request, :remote_ip), request_headers: @params.dig(:request, :headers), user: @params.dig(:request, :user), job: @params.dig(:job), revision: revision } end private def location @params[:location] || $PROGRAM_NAME end def backtrace @_backtrace ||= begin cleaner = ActiveSupport::BacktraceCleaner.new gem_paths.each { |gem_path| cleaner.add_filter { |line| line.sub(gem_path, '[GEM_ROOT]/') } } cleaner.add_filter { |line| line.sub(ruby_path, '[RUBY_ROOT]/') } cleaner.add_filter { |line| line.sub(Nadir.config.root.to_s, '') } cleaner.add_filter { |line| line.sub('/', '') } cleaner.add_filter { |line| line.start_with?('.') ? line.sub('.', '') : line } cleaner.clean(@exception.backtrace) end end def fingerprint first_backtrace_line = backtrace.find { |trace| trace !~ /pry|irb/ } checksum = [first_backtrace_line, @exception.class].join('|') Digest::SHA1.hexdigest checksum end def gem_paths @gem_paths ||= Gem.path | [Gem.default_dir] end def ruby_path ENV['RUBY_ROOT'] end def revision `git rev-parse HEAD` end end end
Version data entries
1 entries across 1 versions & 1 rubygems
Version | Path |
---|---|
nadir-1.1.3 | lib/nadir/notification.rb |