class ElasticAPM::Config
@api private
def app=(app)
def app=(app) case app_type?(app) when :sinatra set_sinatra(app) when :rails set_rails(app) else self.service_name = 'ruby' end end
def app_type?(app)
def app_type?(app) if defined?(::Rails::Application) && app.is_a?(::Rails::Application) return :rails end if app.is_a?(Class) && app.superclass.to_s == 'Sinatra::Base' return :sinatra end nil end
def assign(update)
def assign(update) return unless update update.each { |key, value| send(:"#{key}=", value) } end
def available_instrumentations
def available_instrumentations %w[ action_dispatch azure_storage_table delayed_job dynamo_db elasticsearch faraday http json mongo net_http rake racecar redis resque s3 sequel shoryuken sidekiq sinatra sneakers sns sqs sucker_punch tilt ] end
def build_ecs_logger
def build_ecs_logger require 'ecs_logging/logger' ::EcsLogging::Logger.new(log_path == '-' ? $stdout : log_path).tap do |logger| logger.level = log_level end end
def build_logger
def build_logger if self.log_ecs_reformatting == 'override' begin return build_ecs_logger rescue LoadError logger.info "Attempted to use EcsLogging::Logger but the gem couldn't be " \ "loaded so a ::Logger was created instead. Check if you have the `ecs-logging` " \ "gem installed and attempt to start the agent again." end end Logger.new(log_path == '-' ? $stdout : log_path).tap do |logger| logger.level = log_level end end
def collect_metrics?
def collect_metrics? metrics_interval > 0 end
def enabled_instrumentations
def enabled_instrumentations available_instrumentations - disable_instrumentations end
def format_name(str)
def format_name(str) str&.gsub('::', '_') end
def initialize(options = {})
def initialize(options = {}) @options = load_schema assign(options) # Pick out config_file specifically as we need it now to load it, # but still need the other env vars to have precedence env = load_env if (env_config_file = env.delete(:config_file)) self.config_file = env_config_file end assign(load_config_file) assign(env) yield self if block_given? if self.logger.nil? || self.log_path self.logger = build_logger end @__view_paths ||= [] @__root_path ||= Dir.pwd end
def inspect
def inspect super.split.first + '>' end
def load_config_file
def load_config_file return unless File.exist?(config_file) read = File.read(config_file) evaled = ERB.new(read).result YAML.safe_load(evaled) end
def load_env
def load_env @options.values.each_with_object({}) do |option, opts| next unless (value = ENV[option.env_key]) opts[option.key] = value end end
def log_ecs_formatting
def log_ecs_formatting log_ecs_reformatting end
def log_ecs_formatting=(value)
def log_ecs_formatting=(value) @options[:log_ecs_reformatting].set(value) end
def rails_app_name(app)
def rails_app_name(app) if ::Rails::VERSION::MAJOR >= 6 app.class.module_parent_name else app.class.parent_name end end
def replace_options(new_options)
def replace_options(new_options) return if new_options.nil? || new_options.empty? options_copy = @options.dup new_options.each do |key, value| options_copy.fetch(key.to_sym).set(value) end @options = options_copy end
def set_rails(app)
def set_rails(app) self.service_name ||= format_name(service_name || rails_app_name(app)) self.framework_name ||= 'Ruby on Rails' self.framework_version ||= ::Rails::VERSION::STRING self.logger ||= ::Rails.logger self.log_level ||= ::Rails.logger.log_level self.__root_path = ::Rails.root.to_s self.__view_paths = app.config.paths['app/views'].existent + [::Rails.root.to_s] end
def set_sinatra(app)
def set_sinatra(app) self.service_name = format_name(service_name || app.to_s) self.framework_name = framework_name || 'Sinatra' self.framework_version = framework_version || ::Sinatra::VERSION self.__root_path = Dir.pwd end
def span_frames_min_duration=(value)
def span_frames_min_duration=(value) super @span_frames_min_duration_us = nil end
def span_frames_min_duration?
def span_frames_min_duration? span_frames_min_duration != 0 end
def span_frames_min_duration_us
def span_frames_min_duration_us @span_frames_min_duration_us ||= span_frames_min_duration * 1_000_000 end
def ssl_context
def ssl_context return unless use_ssl? @ssl_context ||= OpenSSL::SSL::SSLContext.new.tap do |context| if server_ca_cert_file context.ca_file = server_ca_cert_file else context.cert_store = OpenSSL::X509::Store.new.tap(&:set_default_paths) end context.verify_mode = if verify_server_cert OpenSSL::SSL::VERIFY_PEER else OpenSSL::SSL::VERIFY_NONE end end end
def use_ssl?
def use_ssl? server_url.start_with?('https') end
def version
def version @version ||= ServerInfo.new(self).version end