Class: Parse::AggregationResult
- Inherits:
-
Object
- Object
- Parse::AggregationResult
- Defined in:
- lib/parse/query.rb
Overview
Wrapper class for custom aggregation results (from $group, $project, etc.) Provides both hash-style access and method-style access to fields. Field names are automatically converted from camelCase to snake_case.
Instance Method Summary collapse
-
#[](key) ⇒ Object
Hash-style access with string or symbol keys.
-
#initialize(data) ⇒ AggregationResult
constructor
A new instance of AggregationResult.
- #inspect ⇒ Object
-
#key?(key) ⇒ Boolean
Check if a key exists.
-
#keys ⇒ Array<Symbol>
Get all keys (snake_case symbols).
-
#method_missing(method_name, *args, &block) ⇒ Object
Method-style access to fields.
-
#raw ⇒ Hash
Get the raw data as originally received.
- #respond_to_missing?(method_name, include_private = false) ⇒ Boolean
-
#to_h ⇒ Hash
(also: #to_hash)
Convert to hash with snake_case symbol keys.
Constructor Details
#initialize(data) ⇒ AggregationResult
Returns a new instance of AggregationResult.
5819 5820 5821 5822 5823 5824 5825 5826 5827 5828 5829 |
# File 'lib/parse/query.rb', line 5819 def initialize(data) @data = {} @raw_data = data # Convert keys to snake_case and store data.each do |key, value| snake_key = Parse::Query.to_snake_case(key.to_s) @data[snake_key.to_sym] = value @data[key.to_s] = value # Also keep original key for hash access end end |
Dynamic Method Handling
This class handles dynamic methods through the method_missing method
#method_missing(method_name, *args, &block) ⇒ Object
Method-style access to fields
5867 5868 5869 5870 5871 5872 5873 5874 |
# File 'lib/parse/query.rb', line 5867 def method_missing(method_name, *args, &block) key = method_name.to_sym if @data.key?(key) @data[key] else super end end |
Instance Method Details
#[](key) ⇒ Object
Hash-style access with string or symbol keys
5834 5835 5836 |
# File 'lib/parse/query.rb', line 5834 def [](key) @data[key.to_s] || @data[key.to_sym] end |
#inspect ⇒ Object
5880 5881 5882 |
# File 'lib/parse/query.rb', line 5880 def inspect "#<Parse::AggregationResult #{to_h.inspect}>" end |
#key?(key) ⇒ Boolean
Check if a key exists
5841 5842 5843 |
# File 'lib/parse/query.rb', line 5841 def key?(key) @data.key?(key.to_s) || @data.key?(key.to_sym) end |
#keys ⇒ Array<Symbol>
Get all keys (snake_case symbols)
5847 5848 5849 |
# File 'lib/parse/query.rb', line 5847 def keys @data.keys.select { |k| k.is_a?(Symbol) } end |
#raw ⇒ Hash
Get the raw data as originally received
5862 5863 5864 |
# File 'lib/parse/query.rb', line 5862 def raw @raw_data end |
#respond_to_missing?(method_name, include_private = false) ⇒ Boolean
5876 5877 5878 |
# File 'lib/parse/query.rb', line 5876 def respond_to_missing?(method_name, include_private = false) @data.key?(method_name.to_sym) || super end |