module Appsignal class Hooks class << self def register(name, hook) hooks[name] = hook end def load_hooks hooks.each do |name, hook| hook.try_to_install(name) end end def hooks @hooks ||= {} end end class Hook def self.register(name, hook=self) Appsignal::Hooks.register(name, hook.new) end def try_to_install(name) if dependencies_present? && !installed? Appsignal.logger.info("Installing #{name} hook") begin install @installed = true rescue => ex Appsignal.logger.error("Error while installing #{name} hook: #{ex}") end end end def installed? !! @installed end def dependencies_present? raise NotImplementedError end def install raise NotImplementedError end end module Helpers def string_or_inspect(string_or_other) if string_or_other.is_a?(String) string_or_other else string_or_other.inspect end end def truncate(text) text.size > 200 ? "#{text[0...197]}..." : text end def extract_value(object_or_hash, field, default_value=nil, convert_to_s=false) value = if object_or_hash.respond_to?(:[]) object_or_hash[field] elsif object_or_hash.respond_to?(field) object_or_hash.send(field) end || default_value if convert_to_s value.to_s else value end end def format_args(args) args.map do |arg| truncate(string_or_inspect(arg)) end end end end end require 'appsignal/hooks/celluloid' require 'appsignal/hooks/delayed_job' require 'appsignal/hooks/net_http' require 'appsignal/hooks/passenger' require 'appsignal/hooks/puma' require 'appsignal/hooks/rake' require 'appsignal/hooks/redis' require 'appsignal/hooks/sequel' require 'appsignal/hooks/sidekiq' require 'appsignal/hooks/unicorn' require 'appsignal/hooks/mongo_ruby_driver'