Sha256: 1b7e9a4fa6e279590be869a25897ee92ece95a6ac51cac0a3e572d0473657761

Contents?: true

Size: 1.25 KB

Versions: 6

Compression:

Stored size: 1.25 KB

Contents

module Switchman
  module ActiveRecord
    module LogSubscriber
      # sadly, have to completely replace this
      def sql(event)
        self.class.runtime += event.duration
        return unless logger.debug?

        payload = event.payload

        return if ::ActiveRecord::LogSubscriber::IGNORE_PAYLOAD_NAMES.include?(payload[:name])

        name  = "#{payload[:name]} (#{event.duration.round(1)}ms)"
        name  = "CACHE #{name}" if payload[:cached]
        sql   = payload[:sql].squeeze(' '.freeze)
        binds = nil
        shard = payload[:shard]
        shard = "  [#{shard[:database_server_id]}:#{shard[:id]} #{shard[:env]}]" if shard

        unless (payload[:binds] || []).empty?
          use_old_format = (::Rails.version < '5.1.5')
          args = use_old_format ?
            [payload[:binds], payload[:type_casted_binds]] :
            [payload[:type_casted_binds]]
          casted_params = type_casted_binds(*args)
          binds = "  " + payload[:binds].zip(casted_params).map { |attr, value|
            render_bind(attr, value)
          }.inspect
        end

        name = colorize_payload_name(name, payload[:name])
        sql  = color(sql, sql_color(sql), true)

        debug "  #{name}  #{sql}#{binds}#{shard}"
      end
    end
  end
end

Version data entries

6 entries across 6 versions & 1 rubygems

Version Path
switchman-2.0.1 lib/switchman/active_record/log_subscriber.rb
switchman-2.0.0 lib/switchman/active_record/log_subscriber.rb
switchman-1.16.0 lib/switchman/active_record/log_subscriber.rb
switchman-1.15.2 lib/switchman/active_record/log_subscriber.rb
switchman-1.15.1 lib/switchman/active_record/log_subscriber.rb
switchman-1.15.0 lib/switchman/active_record/log_subscriber.rb