Class: Cash::Query::Abstract
- Inherits:
-
Object
- Object
- Cash::Query::Abstract
- Defined in:
- lib/cash/query/abstract.rb
Direct Known Subclasses
Constant Summary collapse
- DESC =
/DESC/i
Class Method Summary collapse
Instance Method Summary collapse
- #calculation? ⇒ Boolean
-
#initialize(active_record, options1, options2) ⇒ Abstract
constructor
A new instance of Abstract.
- #limit ⇒ Object
- #offset ⇒ Object
- #order ⇒ Object
- #perform(find_options = {}, get_options = {}) ⇒ Object
Constructor Details
#initialize(active_record, options1, options2) ⇒ Abstract
Returns a new instance of Abstract.
10 11 12 |
# File 'lib/cash/query/abstract.rb', line 10 def initialize(active_record, , ) @active_record, @options1, @options2 = active_record, , || {} end |
Class Method Details
.perform(*args) ⇒ Object
6 7 8 |
# File 'lib/cash/query/abstract.rb', line 6 def self.perform(*args) new(*args).perform end |
Instance Method Details
#calculation? ⇒ Boolean
49 50 51 |
# File 'lib/cash/query/abstract.rb', line 49 def calculation? false end |
#limit ⇒ Object
41 42 43 |
# File 'lib/cash/query/abstract.rb', line 41 def limit @limit ||= @options1[:limit] || @options2[:limit] end |
#offset ⇒ Object
45 46 47 |
# File 'lib/cash/query/abstract.rb', line 45 def offset @offset ||= @options1[:offset] || @options2[:offset] || 0 end |
#order ⇒ Object
28 29 30 31 32 33 34 35 36 37 38 39 |
# File 'lib/cash/query/abstract.rb', line 28 def order @order ||= begin if order_sql = @options1[:order] || @options2[:order] matched, table_name, column_name, direction = *(ORDER.match(order_sql.to_s)) [column_name, direction =~ DESC ? :desc : :asc] else ['id', :asc] end end rescue TypeError ['id', :asc] end |
#perform(find_options = {}, get_options = {}) ⇒ Object
14 15 16 17 18 19 20 21 22 23 24 |
# File 'lib/cash/query/abstract.rb', line 14 def perform( = {}, = {}) if cache_config = cacheable?(@options1, @options2, ) cache_keys, index = cache_keys(cache_config[0]), cache_config[1] misses, missed_keys, objects = hit_or_miss(cache_keys, index, ) format_results(cache_keys, choose_deserialized_objects_if_possible(missed_keys, cache_keys, misses, objects)) else logger.debug(" \e[1;4;31mUNCACHEABLE\e[0m #{table_name} - #{.inspect} - #{.inspect} - #{@options1.inspect} - #{@options2.inspect}") if logger uncacheable end end |