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.
5373 5374 5375 5376 5377 5378 5379 5380 5381 5382 5383 |
# File 'lib/parse/query.rb', line 5373 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
5421 5422 5423 5424 5425 5426 5427 5428 |
# File 'lib/parse/query.rb', line 5421 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
5388 5389 5390 |
# File 'lib/parse/query.rb', line 5388 def [](key) @data[key.to_s] || @data[key.to_sym] end |
#inspect ⇒ Object
5434 5435 5436 |
# File 'lib/parse/query.rb', line 5434 def inspect "#<Parse::AggregationResult #{to_h.inspect}>" end |
#key?(key) ⇒ Boolean
Check if a key exists
5395 5396 5397 |
# File 'lib/parse/query.rb', line 5395 def key?(key) @data.key?(key.to_s) || @data.key?(key.to_sym) end |
#keys ⇒ Array<Symbol>
Get all keys (snake_case symbols)
5401 5402 5403 |
# File 'lib/parse/query.rb', line 5401 def keys @data.keys.select { |k| k.is_a?(Symbol) } end |
#raw ⇒ Hash
Get the raw data as originally received
5416 5417 5418 |
# File 'lib/parse/query.rb', line 5416 def raw @raw_data end |
#respond_to_missing?(method_name, include_private = false) ⇒ Boolean
5430 5431 5432 |
# File 'lib/parse/query.rb', line 5430 def respond_to_missing?(method_name, include_private = false) @data.key?(method_name.to_sym) || super end |