sergio-fry/youtube-fetcher

View on GitHub
app/services/search.rb

Summary

Maintainability
A
0 mins
Test Coverage
A
100%
class Search
  LIMIT = 100

  def self.call(query)
    Search.new.call query
  end

  def initialize
  end

  def call(query)
    select(query).map do |row|
      case row['type']
      when 'Podcast'
        Podcast.find(row['id'])
      when 'Episode'
        Video.new row['origin_id'], Episode.find(row['id'])
      end
    end
  end

  private

  def select(query)
    ApplicationRecord.connection.select_all <<-SQL
    (SELECT id, origin_id, 'Podcast' AS type FROM podcasts WHERE title ILIKE '%#{query}%' ORDER BY created_at DESC LIMIT #{LIMIT})
    UNION
    (SELECT id, origin_id, 'Episode' AS type FROM episodes WHERE title ILIKE '%#{query}%' ORDER BY created_at DESC LIMIT #{LIMIT})
    SQL
  end
end