Sha256: bcef24cd60069f7288f0748942c03a6d93e4b7f00bc4282c89cc3b82ef50c6f9

Contents?: true

Size: 1.18 KB

Versions: 3

Compression:

Stored size: 1.18 KB

Contents

ActiveRecord::LogSubscriber
module ActiveRecord
  class LogSubscriber
    def sql(event)
      self.class.runtime += event.duration

      return unless logger.debug?

      payload = event.payload
      name    = payload[:name]
      return if IGNORE_PAYLOAD_NAMES.include?(name)

      log_payload = {
        sql:      payload[:sql],
      }
      log = {
        message:  name,
        payload:  log_payload,
        duration: event.duration
      }
      unless (payload[:binds] || []).empty?
        log_payload[:binds] = binds = {}
        # Changed with Rails 5
        if Rails.version.to_f >= 5.1
          casted_params = type_casted_binds(payload[:binds], payload[:type_casted_binds])
          payload[:binds].zip(casted_params).map { |attr, value|
            render_bind(attr, value)
          }
        elsif Rails.version.to_i >= 5
          payload[:binds].each do |attr|
            attr_name, value = render_bind(attr)
            binds[attr_name] = value
          end
        else
          payload[:binds].each do |col, v|
            attr_name, value = render_bind(col, v)
            binds[attr_name] = value
          end
        end
      end
      debug(log)
    end

  end
end

Version data entries

3 entries across 3 versions & 1 rubygems

Version Path
rails_semantic_logger-4.1.1 lib/rails_semantic_logger/extensions/active_record/log_subscriber.rb
rails_semantic_logger-4.1.0 lib/rails_semantic_logger/extensions/active_record/log_subscriber.rb
rails_semantic_logger-4.0.1 lib/rails_semantic_logger/extensions/active_record/log_subscriber.rb