/graylog-storage-elasticsearch7/src/main/java/org/graylog/storage/elasticsearch7/views/searchtypes/pivot/buckets/ESValuesHandler.java

https://github.com/Graylog2/graylog2-server · Java · 91 lines · 69 code · 6 blank · 16 comment · 4 complexity · b41980752f9dd2286121be6fa599058f MD5 · raw file

  1. /*
  2. * Copyright (C) 2020 Graylog, Inc.
  3. *
  4. * This program is free software: you can redistribute it and/or modify
  5. * it under the terms of the Server Side Public License, version 1,
  6. * as published by MongoDB, Inc.
  7. *
  8. * This program is distributed in the hope that it will be useful,
  9. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  10. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  11. * Server Side Public License for more details.
  12. *
  13. * You should have received a copy of the Server Side Public License
  14. * along with this program. If not, see
  15. * <http://www.mongodb.com/licensing/server-side-public-license>.
  16. */
  17. package org.graylog.storage.elasticsearch7.views.searchtypes.pivot.buckets;
  18. import org.graylog.plugins.views.search.Query;
  19. import org.graylog.plugins.views.search.searchtypes.pivot.Pivot;
  20. import org.graylog.plugins.views.search.searchtypes.pivot.PivotSort;
  21. import org.graylog.plugins.views.search.searchtypes.pivot.SeriesSort;
  22. import org.graylog.plugins.views.search.searchtypes.pivot.SeriesSpec;
  23. import org.graylog.plugins.views.search.searchtypes.pivot.SortSpec;
  24. import org.graylog.plugins.views.search.searchtypes.pivot.buckets.Values;
  25. import org.graylog.shaded.elasticsearch7.org.elasticsearch.search.aggregations.AggregationBuilder;
  26. import org.graylog.shaded.elasticsearch7.org.elasticsearch.search.aggregations.AggregationBuilders;
  27. import org.graylog.shaded.elasticsearch7.org.elasticsearch.search.aggregations.BucketOrder;
  28. import org.graylog.shaded.elasticsearch7.org.elasticsearch.search.aggregations.bucket.terms.Terms;
  29. import org.graylog.shaded.elasticsearch7.org.elasticsearch.search.aggregations.bucket.terms.TermsAggregationBuilder;
  30. import org.graylog.storage.elasticsearch7.views.ESGeneratedQueryContext;
  31. import org.graylog.storage.elasticsearch7.views.searchtypes.pivot.ESPivot;
  32. import org.graylog.storage.elasticsearch7.views.searchtypes.pivot.ESPivotBucketSpecHandler;
  33. import javax.annotation.Nonnull;
  34. import java.util.Collections;
  35. import java.util.List;
  36. import java.util.Objects;
  37. import java.util.Optional;
  38. import java.util.stream.Collectors;
  39. import java.util.stream.Stream;
  40. public class ESValuesHandler extends ESPivotBucketSpecHandler<Values, Terms> {
  41. @Nonnull
  42. @Override
  43. public Optional<AggregationBuilder> doCreateAggregation(String name, Pivot pivot, Values valuesSpec, ESPivot searchTypeHandler, ESGeneratedQueryContext esGeneratedQueryContext, Query query) {
  44. final List<BucketOrder> ordering = orderListForPivot(pivot, valuesSpec, esGeneratedQueryContext);
  45. final TermsAggregationBuilder builder = AggregationBuilders.terms(name)
  46. .minDocCount(1)
  47. .field(valuesSpec.field())
  48. .order(ordering.isEmpty() ? Collections.singletonList(BucketOrder.count(false)) : ordering)
  49. .size(valuesSpec.limit());
  50. record(esGeneratedQueryContext, pivot, valuesSpec, name, Terms.class);
  51. return Optional.of(builder);
  52. }
  53. private List<BucketOrder> orderListForPivot(Pivot pivot, Values valuesSpec, ESGeneratedQueryContext esGeneratedQueryContext) {
  54. return pivot.sort()
  55. .stream()
  56. .map(sortSpec -> {
  57. if (sortSpec instanceof PivotSort && valuesSpec.field().equals(sortSpec.field())) {
  58. return BucketOrder.key(sortSpec.direction().equals(SortSpec.Direction.Ascending));
  59. }
  60. if (sortSpec instanceof SeriesSort) {
  61. final Optional<SeriesSpec> matchingSeriesSpec = pivot.series()
  62. .stream()
  63. .filter(series -> series.literal().equals(sortSpec.field()))
  64. .findFirst();
  65. return matchingSeriesSpec
  66. .map(seriesSpec -> {
  67. if (seriesSpec.literal().equals("count()")) {
  68. return BucketOrder.count(sortSpec.direction().equals(SortSpec.Direction.Ascending));
  69. }
  70. return BucketOrder.aggregation(esGeneratedQueryContext.seriesName(seriesSpec, pivot), sortSpec.direction().equals(SortSpec.Direction.Ascending));
  71. })
  72. .orElse(null);
  73. }
  74. return null;
  75. })
  76. .filter(Objects::nonNull)
  77. .collect(Collectors.toList());
  78. }
  79. @Override
  80. public Stream<Bucket> doHandleResult(Values bucketSpec,
  81. Terms termsAggregation) {
  82. return termsAggregation.getBuckets().stream()
  83. .map(entry -> Bucket.create(entry.getKeyAsString(), entry));
  84. }
  85. }