123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657 |
- // Copyright 2012-2015 Oliver Eilhard. All rights reserved.
- // Use of this source code is governed by a MIT-license.
- // See http://olivere.mit-license.org/license.txt for details.
- package elastic
- // ChildrenAggregation is a special single bucket aggregation that enables
- // aggregating from buckets on parent document types to buckets on child documents.
- // It is available from 1.4.0.Beta1 upwards.
- // See: http://www.elasticsearch.org/guide/en/elasticsearch/reference/current/search-aggregations-bucket-children-aggregation.html
- type ChildrenAggregation struct {
- typ string
- subAggregations map[string]Aggregation
- }
- func NewChildrenAggregation() ChildrenAggregation {
- a := ChildrenAggregation{
- subAggregations: make(map[string]Aggregation),
- }
- return a
- }
- func (a ChildrenAggregation) Type(typ string) ChildrenAggregation {
- a.typ = typ
- return a
- }
- func (a ChildrenAggregation) SubAggregation(name string, subAggregation Aggregation) ChildrenAggregation {
- a.subAggregations[name] = subAggregation
- return a
- }
- func (a ChildrenAggregation) Source() interface{} {
- // Example:
- // {
- // "aggs" : {
- // "to-answers" : {
- // "type" : "answer"
- // }
- // }
- // }
- // This method returns only the { "type" : ... } part.
- source := make(map[string]interface{})
- source["type"] = a.typ
- // AggregationBuilder (SubAggregations)
- if len(a.subAggregations) > 0 {
- aggsMap := make(map[string]interface{})
- source["aggregations"] = aggsMap
- for name, aggregate := range a.subAggregations {
- aggsMap[name] = aggregate.Source()
- }
- }
- return source
- }
|