Sha256: f598957d1435d278cfc3af103c7d07464f11cbf9eaaa13f493e11d5d24ecef76

Contents?: true

Size: 842 Bytes

Versions: 5

Compression:

Stored size: 842 Bytes

Contents

# frozen_string_literal: true

require 'elastic_apm/util/lru_cache'

module ElasticAPM
  # @api private
  class SqlSummarizer
    DEFAULT = 'SQL'
    TABLE_REGEX = %{["'`]?([A-Za-z0-9]+)}

    REGEXES = {
      /^BEGIN/i => 'BEGIN',
      /^COMMIT/i => 'COMMIT',
      /^SELECT .* FROM #{TABLE_REGEX}/i => 'SELECT FROM ',
      /^INSERT INTO #{TABLE_REGEX}/i => 'INSERT INTO ',
      /^UPDATE #{TABLE_REGEX}/i => 'UPDATE ',
      /^DELETE FROM #{TABLE_REGEX}/i => 'DELETE FROM '
    }.freeze

    FORMAT = '%s%s'

    def self.cache
      @cache ||= Util::LruCache.new
    end

    def summarize(sql)
      self.class.cache[sql] ||=
        REGEXES.find do |regex, sig|
          if (match = sql.match(regex))
            break format(FORMAT, sig, match[1] && match[1].gsub(/["']/, ''))
          end
        end || DEFAULT
    end
  end
end

Version data entries

5 entries across 5 versions & 1 rubygems

Version Path
elastic-apm-2.1.2 lib/elastic_apm/sql_summarizer.rb
elastic-apm-2.1.1 lib/elastic_apm/sql_summarizer.rb
elastic-apm-2.1.0 lib/elastic_apm/sql_summarizer.rb
elastic-apm-2.0.1 lib/elastic_apm/sql_summarizer.rb
elastic-apm-2.0.0 lib/elastic_apm/sql_summarizer.rb