All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.datadog.api.client.v2.model.SpansAggregationFunction Maven / Gradle / Ivy

/*
 * Unless explicitly stated otherwise all files in this repository are licensed under the Apache-2.0 License.
 * This product includes software developed at Datadog (https://www.datadoghq.com/).
 * Copyright 2019-Present Datadog, Inc.
 */

package com.datadog.api.client.v2.model;

import com.datadog.api.client.ModelEnum;
import com.fasterxml.jackson.annotation.JsonCreator;
import com.fasterxml.jackson.core.JsonGenerator;
import com.fasterxml.jackson.core.JsonProcessingException;
import com.fasterxml.jackson.databind.SerializerProvider;
import com.fasterxml.jackson.databind.annotation.JsonSerialize;
import com.fasterxml.jackson.databind.ser.std.StdSerializer;
import java.io.IOException;
import java.util.Arrays;
import java.util.HashSet;
import java.util.Set;

/** An aggregation function. */
@JsonSerialize(using = SpansAggregationFunction.SpansAggregationFunctionSerializer.class)
public class SpansAggregationFunction extends ModelEnum {

  private static final Set allowedValues =
      new HashSet(
          Arrays.asList(
              "count",
              "cardinality",
              "pc75",
              "pc90",
              "pc95",
              "pc98",
              "pc99",
              "sum",
              "min",
              "max",
              "avg",
              "median"));

  public static final SpansAggregationFunction COUNT = new SpansAggregationFunction("count");
  public static final SpansAggregationFunction CARDINALITY =
      new SpansAggregationFunction("cardinality");
  public static final SpansAggregationFunction PERCENTILE_75 = new SpansAggregationFunction("pc75");
  public static final SpansAggregationFunction PERCENTILE_90 = new SpansAggregationFunction("pc90");
  public static final SpansAggregationFunction PERCENTILE_95 = new SpansAggregationFunction("pc95");
  public static final SpansAggregationFunction PERCENTILE_98 = new SpansAggregationFunction("pc98");
  public static final SpansAggregationFunction PERCENTILE_99 = new SpansAggregationFunction("pc99");
  public static final SpansAggregationFunction SUM = new SpansAggregationFunction("sum");
  public static final SpansAggregationFunction MIN = new SpansAggregationFunction("min");
  public static final SpansAggregationFunction MAX = new SpansAggregationFunction("max");
  public static final SpansAggregationFunction AVG = new SpansAggregationFunction("avg");
  public static final SpansAggregationFunction MEDIAN = new SpansAggregationFunction("median");

  SpansAggregationFunction(String value) {
    super(value, allowedValues);
  }

  public static class SpansAggregationFunctionSerializer
      extends StdSerializer {
    public SpansAggregationFunctionSerializer(Class t) {
      super(t);
    }

    public SpansAggregationFunctionSerializer() {
      this(null);
    }

    @Override
    public void serialize(
        SpansAggregationFunction value, JsonGenerator jgen, SerializerProvider provider)
        throws IOException, JsonProcessingException {
      jgen.writeObject(value.value);
    }
  }

  @JsonCreator
  public static SpansAggregationFunction fromValue(String value) {
    return new SpansAggregationFunction(value);
  }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy