Class: Elasticated::RangeAggregation
- Inherits:
-
Aggregation
- Object
- Aggregation
- Elasticated::RangeAggregation
- Includes:
- Subaggregated
- Defined in:
- lib/elasticated/aggregations/range_aggregation.rb
Instance Attribute Summary collapse
-
#_conditions ⇒ Object
Returns the value of attribute _conditions.
Attributes included from Subaggregated
Attributes inherited from Aggregation
#alias_name, #extra_params, #field
Instance Method Summary collapse
- #build ⇒ Object
- #default_name ⇒ Object
-
#initialize(field, *args, &block) ⇒ RangeAggregation
constructor
A new instance of RangeAggregation.
- #parse(response) ⇒ Object
Methods included from Subaggregated
Methods inherited from Aggregation
Methods included from Clonable
Methods included from BlockEvaluation
Constructor Details
#initialize(field, *args, &block) ⇒ RangeAggregation
Returns a new instance of RangeAggregation.
7 8 9 10 |
# File 'lib/elasticated/aggregations/range_aggregation.rb', line 7 def initialize(field, *args, &block) super initialize_subaggregations RangeAggregationEvaluator.new, &block end |
Instance Attribute Details
#_conditions ⇒ Object
Returns the value of attribute _conditions.
5 6 7 |
# File 'lib/elasticated/aggregations/range_aggregation.rb', line 5 def _conditions @_conditions end |
Instance Method Details
#build ⇒ Object
16 17 18 19 20 21 22 23 24 |
# File 'lib/elasticated/aggregations/range_aggregation.rb', line 16 def build # _subaggregations is a RangeAggregationEvaluator, so... ranges = _subaggregations.build_ranges body_struct = { field: field, keyed: true, ranges: ranges } body_struct.merge! extra_params body = { range: body_struct } body.merge! build_subaggregations body end |
#default_name ⇒ Object
12 13 14 |
# File 'lib/elasticated/aggregations/range_aggregation.rb', line 12 def default_name "range_over_#{field}" end |
#parse(response) ⇒ Object
26 27 28 29 30 31 32 |
# File 'lib/elasticated/aggregations/range_aggregation.rb', line 26 def parse(response) response['buckets'].inject({}) do |hash, (key_name, values)| range_body = { 'count' => values['doc_count'] } range_body.merge! parse_subaggregations(values) hash.merge key_name => range_body end end |