Sha256: 0ecb9c6c63f4af3ebee6fd79eaf425a5ea623a75036483ce0c59dce895b65942
Contents?: true
Size: 1.66 KB
Versions: 4
Compression:
Stored size: 1.66 KB
Contents
module Datagrid module Drivers class MongoMapper < AbstractDriver #:nodoc: def self.match?(scope) return false unless defined?(::MongoMapper) if scope.is_a?(Class) scope.ancestors.include?(::MongoMapper::Document) else scope.is_a?(::Plucky::Query) end end def to_scope(scope) scope.where end def where(scope, attribute, value) scope.where(attribute => value) end def asc(scope, order) scope.sort(order.asc) end def desc(scope, order) scope.sort(order.desc) end def default_order(scope, column_name) has_column?(scope, column_name) ? column_name : nil end def greater_equal(scope, field, value) scope.where(field => {"$gte" => value}) end def less_equal(scope, field, value) scope.where(field => {"$lte" => value}) end def has_column?(scope, column_name) scope.key?(column_name) end def is_timestamp?(scope, column_name) #TODO implement the support false end def contains(scope, field, value) scope(field => Regexp.compile(Regexp.escape(value))) end def column_names(scope) [] # TODO: implement support end def batch_each(scope, batch_size, &block) current_page = 0 loop do batch = scope.skip(current_page * batch_size).limit(batch_size).to_a return if batch.empty? scope.skip(current_page * batch_size).limit(batch_size).each do |item| yield(item) end current_page+=1 end end end end end
Version data entries
4 entries across 4 versions & 1 rubygems