123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566 |
- // 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
- // MissingAggregation is a field data based single bucket aggregation,
- // that creates a bucket of all documents in the current document set context
- // that are missing a field value (effectively, missing a field or having
- // the configured NULL value set). This aggregator will often be used in
- // conjunction with other field data bucket aggregators (such as ranges)
- // to return information for all the documents that could not be placed
- // in any of the other buckets due to missing field data values.
- // See: http://www.elasticsearch.org/guide/en/elasticsearch/reference/current/search-aggregations-bucket-missing-aggregation.html
- type MissingAggregation struct {
- field string
- subAggregations map[string]Aggregation
- }
- func NewMissingAggregation() MissingAggregation {
- a := MissingAggregation{
- subAggregations: make(map[string]Aggregation),
- }
- return a
- }
- func (a MissingAggregation) Field(field string) MissingAggregation {
- a.field = field
- return a
- }
- func (a MissingAggregation) SubAggregation(name string, subAggregation Aggregation) MissingAggregation {
- a.subAggregations[name] = subAggregation
- return a
- }
- func (a MissingAggregation) Source() interface{} {
- // Example:
- // {
- // "aggs" : {
- // "products_without_a_price" : {
- // "missing" : { "field" : "price" }
- // }
- // }
- // }
- // This method returns only the { "missing" : { ... } } part.
- source := make(map[string]interface{})
- opts := make(map[string]interface{})
- source["missing"] = opts
- if a.field != "" {
- opts["field"] = a.field
- }
- // 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
- }
|