Sha256: 8292d00b90e83b32f1e633e07a007bd2e794ba2887f837abf13853878fcc592e
Contents?: true
Size: 1.55 KB
Versions: 4
Compression:
Stored size: 1.55 KB
Contents
module Services class Query include ObjectClass class << self delegate :call, to: :new end def call(ids = [], conditions = {}) raise ArgumentError, 'ids parameter must not be nil.' if ids.nil? ids, conditions = Array(ids), conditions.symbolize_keys object_table_id = "#{object_class.table_name}.id" special_conditions = conditions.extract!(:order, :limit, :page, :per_page) special_conditions[:order] = object_table_id unless special_conditions.has_key?(:order) scope = object_class.public_send(Rails::VERSION::MAJOR == 3 ? :scoped : :all) scope = scope.where(object_table_id => ids) unless ids.empty? unless conditions.empty? scope = process(scope, conditions) # If a JOIN is involved, use a subquery to make sure we're getting DISTINCT records. if scope.to_sql =~ / join /i scope = object_class.where(id: scope.select("DISTINCT #{object_table_id}")) end end special_conditions.each do |k, v| case k when :order next unless v order = case v when 'random' then 'RANDOM()' when /\./ then v else "#{object_class.table_name}.#{v}" end scope = scope.order(order) when :limit scope = scope.limit(v) when :page scope = scope.page(v) when :per_page scope = scope.per(v) else raise ArgumentError, "Unexpected special condition: #{k}" end end scope end end end
Version data entries
4 entries across 4 versions & 1 rubygems
Version | Path |
---|---|
services-4.0.2 | lib/services/query.rb |
services-4.0.1 | lib/services/query.rb |
services-4.0.0 | lib/services/query.rb |
services-3.1.1 | lib/services/query.rb |