Sha256: 551bcdb9d66f24b4ff8710863bfb2d0e9fe534f04aa9f384dd7e43d7e349d208
Contents?: true
Size: 1.3 KB
Versions: 23
Compression:
Stored size: 1.3 KB
Contents
# Copyright (c) 2016 SolarWinds, LLC. # All rights reserved. module AppOpticsAPM module Inst # # ActionController # # This modules contains the instrumentation code specific # to Rails v5 # module ActionController include AppOpticsAPM::Inst::RailsBase def process_action(method_name, *args) kvs = { :Controller => self.class.name, :Action => self.action_name, } request.env['appoptics_apm.controller'] = kvs[:Controller] request.env['appoptics_apm.action'] = kvs[:Action] return super(method_name, *args) unless AppOpticsAPM.tracing? begin kvs[:Backtrace] = AppOpticsAPM::API.backtrace if AppOpticsAPM::Config[:action_controller][:collect_backtraces] AppOpticsAPM::API.log_entry('rails', kvs) super(method_name, *args) rescue Exception => e AppOpticsAPM::API.log_exception('rails', e) if log_rails_error?(e) raise ensure AppOpticsAPM::API.log_exit('rails') end end # # render # # Our render wrapper that calls 'trace', which will log if we are tracing # def render(*args, &blk) trace('actionview') do super(*args, &blk) end end end end end
Version data entries
23 entries across 23 versions & 3 rubygems