Sha256: 1e46ba0cccfc4b0886b1a1382305451c49c9d45618f708b533c0c0c06dcbc531

Contents?: true

Size: 1.53 KB

Versions: 1

Compression:

Stored size: 1.53 KB

Contents

# frozen_string_literal: true

require 'terminal-table'

module RailsPGExtras
  QUERIES =   %i(
    bloat blocking cache_hit
     calls extensions
     index_size index_usage locks
     long_running_queries mandelbrot outliers
     records_rank seq_scans table_indexes_size
     table_size total_index_size total_table_size
     unused_indexes vacuum_stats
  )

  QUERIES.each do |query_name|
    require "rails-pg-extras/queries/#{query_name}"

    define_singleton_method query_name do |options = { in_format: :display_table }|
      run_query(
        query_name: query_name,
        in_format: options.fetch(:in_format)
      )
    end
  end

  def self.run_query(query_name:, in_format:)
    result = connection.execute(self.public_send("#{query_name}_sql"))
    title = self.public_send("#{query_name}_description")
    display_result(result, title: title, in_format: in_format)
  end

  def self.display_result(result, title:, in_format:)
    case in_format
    when :array
      result.values
    when :hash
      result.to_a
    when :raw
      result
    when :display_table
      headings = if result.count > 0
        result[0].keys
      else
        ["No results"]
      end

      puts Terminal::Table.new(
        title: title,
        headings: headings,
        rows: result.values
      )
    else
      raise "Invalid in_format option"
    end
  end

  def self.connection
    ActiveRecord::Base.connection
  end

  private_class_method :connection
  private_class_method :display_result
end

require 'rails-pg-extras/railtie' if defined?(Rails)

Version data entries

1 entries across 1 versions & 1 rubygems

Version Path
rails-pg-extras-0.3.0 lib/rails-pg-extras.rb