Sha256: 0053b3d7d23702cdfd9ebc68ddb15e5c8ccf590e39dcf2ba116b0c3d62d13c69

Contents?: true

Size: 1.88 KB

Versions: 2

Compression:

Stored size: 1.88 KB

Contents

# encoding: utf-8
require 'ting_yun/agent'
require 'ting_yun/support/exception'


module TingYun
  module Instrumentation
    module Support
      module Variables
        attr_accessor :tingyun_code, :tingyun_klass, :tingyun_external, :tingyun_trace
      end
      module ExternalError

        module_function

        def capture_exception(response,request)
          if response && response.code.to_s =~ /^[4,5][0-9][0-9]$/ && response.code.to_s!='401'
            e = TingYun::Support::Exception::InternalServerError.new("#{response.code}: #{response.message}")
            klass = "External/#{request.uri.to_s.gsub(/\/\z/,'').gsub('/','%2F')}/#{request.from}"
            set_attributes(e, klass, response.code)

            TingYun::Agent.notice_error(e,:type=>:exception)
          end
        end

        def handle_error(e,klass)
          case e
            when Errno::ECONNREFUSED
              set_attributes(e, klass, 902)
            when SocketError
              set_attributes(e, klass, 901)
            when OpenSSL::SSL::SSLError
              set_attributes(e, klass, 908)
            when Timeout::Error
              set_attributes(e, klass, 903)
            else
              set_attributes(e, klass, 1000)
          end

          TingYun::Agent.notice_error(e,:type=>:exception)
        end

        def set_attributes(exception, klass, code)
          exception.instance_exec {extend TingYun::Instrumentation::Support::Variables}
          begin
            exception.tingyun_code = code
            exception.tingyun_klass = klass
            exception.tingyun_external = true
            trace = caller.reject! { |t| t.include?('tingyun_rpm') }
            trace = trace.first(20)
            exception.tingyun_trace = trace
          rescue => e
            TingYun::Agent.logger.warn("Failed to set attributes for : #{exception}: ", e)
          end
        end

      end
    end
  end
end

Version data entries

2 entries across 2 versions & 1 rubygems

Version Path
tingyun_rpm-1.6.1 lib/ting_yun/instrumentation/support/external_error.rb
tingyun_rpm-1.5.0 lib/ting_yun/instrumentation/support/external_error.rb