com.datadog.api.client.v2.model.SecurityMonitoringStandardRuleQuery 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.fasterxml.jackson.annotation.JsonAnyGetter;
import com.fasterxml.jackson.annotation.JsonAnySetter;
import com.fasterxml.jackson.annotation.JsonIgnore;
import com.fasterxml.jackson.annotation.JsonInclude;
import com.fasterxml.jackson.annotation.JsonProperty;
import com.fasterxml.jackson.annotation.JsonPropertyOrder;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import java.util.Objects;
/** Query for matching rule. */
@JsonPropertyOrder({
SecurityMonitoringStandardRuleQuery.JSON_PROPERTY_AGGREGATION,
SecurityMonitoringStandardRuleQuery.JSON_PROPERTY_DISTINCT_FIELDS,
SecurityMonitoringStandardRuleQuery.JSON_PROPERTY_GROUP_BY_FIELDS,
SecurityMonitoringStandardRuleQuery.JSON_PROPERTY_HAS_OPTIONAL_GROUP_BY_FIELDS,
SecurityMonitoringStandardRuleQuery.JSON_PROPERTY_METRIC,
SecurityMonitoringStandardRuleQuery.JSON_PROPERTY_METRICS,
SecurityMonitoringStandardRuleQuery.JSON_PROPERTY_NAME,
SecurityMonitoringStandardRuleQuery.JSON_PROPERTY_QUERY
})
@jakarta.annotation.Generated(
value = "https://github.com/DataDog/datadog-api-client-java/blob/master/.generator")
public class SecurityMonitoringStandardRuleQuery {
@JsonIgnore public boolean unparsed = false;
public static final String JSON_PROPERTY_AGGREGATION = "aggregation";
private SecurityMonitoringRuleQueryAggregation aggregation;
public static final String JSON_PROPERTY_DISTINCT_FIELDS = "distinctFields";
private List distinctFields = null;
public static final String JSON_PROPERTY_GROUP_BY_FIELDS = "groupByFields";
private List groupByFields = null;
public static final String JSON_PROPERTY_HAS_OPTIONAL_GROUP_BY_FIELDS =
"hasOptionalGroupByFields";
private Boolean hasOptionalGroupByFields;
public static final String JSON_PROPERTY_METRIC = "metric";
private String metric;
public static final String JSON_PROPERTY_METRICS = "metrics";
private List metrics = null;
public static final String JSON_PROPERTY_NAME = "name";
private String name;
public static final String JSON_PROPERTY_QUERY = "query";
private String query;
public SecurityMonitoringStandardRuleQuery aggregation(
SecurityMonitoringRuleQueryAggregation aggregation) {
this.aggregation = aggregation;
this.unparsed |= !aggregation.isValid();
return this;
}
/**
* The aggregation type.
*
* @return aggregation
*/
@jakarta.annotation.Nullable
@JsonProperty(JSON_PROPERTY_AGGREGATION)
@JsonInclude(value = JsonInclude.Include.USE_DEFAULTS)
public SecurityMonitoringRuleQueryAggregation getAggregation() {
return aggregation;
}
public void setAggregation(SecurityMonitoringRuleQueryAggregation aggregation) {
if (!aggregation.isValid()) {
this.unparsed = true;
}
this.aggregation = aggregation;
}
public SecurityMonitoringStandardRuleQuery distinctFields(List distinctFields) {
this.distinctFields = distinctFields;
return this;
}
public SecurityMonitoringStandardRuleQuery addDistinctFieldsItem(String distinctFieldsItem) {
if (this.distinctFields == null) {
this.distinctFields = new ArrayList<>();
}
this.distinctFields.add(distinctFieldsItem);
return this;
}
/**
* Field for which the cardinality is measured. Sent as an array.
*
* @return distinctFields
*/
@jakarta.annotation.Nullable
@JsonProperty(JSON_PROPERTY_DISTINCT_FIELDS)
@JsonInclude(value = JsonInclude.Include.USE_DEFAULTS)
public List getDistinctFields() {
return distinctFields;
}
public void setDistinctFields(List distinctFields) {
this.distinctFields = distinctFields;
}
public SecurityMonitoringStandardRuleQuery groupByFields(List groupByFields) {
this.groupByFields = groupByFields;
return this;
}
public SecurityMonitoringStandardRuleQuery addGroupByFieldsItem(String groupByFieldsItem) {
if (this.groupByFields == null) {
this.groupByFields = new ArrayList<>();
}
this.groupByFields.add(groupByFieldsItem);
return this;
}
/**
* Fields to group by.
*
* @return groupByFields
*/
@jakarta.annotation.Nullable
@JsonProperty(JSON_PROPERTY_GROUP_BY_FIELDS)
@JsonInclude(value = JsonInclude.Include.USE_DEFAULTS)
public List getGroupByFields() {
return groupByFields;
}
public void setGroupByFields(List groupByFields) {
this.groupByFields = groupByFields;
}
/**
* When false, events without a group-by value are ignored by the rule. When true, events with
* missing group-by fields are processed with N/A
, replacing the missing values.
*
* @return hasOptionalGroupByFields
*/
@jakarta.annotation.Nullable
@JsonProperty(JSON_PROPERTY_HAS_OPTIONAL_GROUP_BY_FIELDS)
@JsonInclude(value = JsonInclude.Include.USE_DEFAULTS)
public Boolean getHasOptionalGroupByFields() {
return hasOptionalGroupByFields;
}
public SecurityMonitoringStandardRuleQuery metric(String metric) {
this.metric = metric;
return this;
}
/**
* (Deprecated) The target field to aggregate over when using the sum or max aggregations.
* metrics
field should be used instead.
*
* @return metric
* @deprecated
*/
@Deprecated
@jakarta.annotation.Nullable
@JsonProperty(JSON_PROPERTY_METRIC)
@JsonInclude(value = JsonInclude.Include.USE_DEFAULTS)
public String getMetric() {
return metric;
}
@Deprecated
public void setMetric(String metric) {
this.metric = metric;
}
public SecurityMonitoringStandardRuleQuery metrics(List metrics) {
this.metrics = metrics;
return this;
}
public SecurityMonitoringStandardRuleQuery addMetricsItem(String metricsItem) {
if (this.metrics == null) {
this.metrics = new ArrayList<>();
}
this.metrics.add(metricsItem);
return this;
}
/**
* Group of target fields to aggregate over when using the sum, max, geo data, or new value
* aggregations. The sum, max, and geo data aggregations only accept one value in this list,
* whereas the new value aggregation accepts up to five values.
*
* @return metrics
*/
@jakarta.annotation.Nullable
@JsonProperty(JSON_PROPERTY_METRICS)
@JsonInclude(value = JsonInclude.Include.USE_DEFAULTS)
public List getMetrics() {
return metrics;
}
public void setMetrics(List metrics) {
this.metrics = metrics;
}
public SecurityMonitoringStandardRuleQuery name(String name) {
this.name = name;
return this;
}
/**
* Name of the query.
*
* @return name
*/
@jakarta.annotation.Nullable
@JsonProperty(JSON_PROPERTY_NAME)
@JsonInclude(value = JsonInclude.Include.USE_DEFAULTS)
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public SecurityMonitoringStandardRuleQuery query(String query) {
this.query = query;
return this;
}
/**
* Query to run on logs.
*
* @return query
*/
@jakarta.annotation.Nullable
@JsonProperty(JSON_PROPERTY_QUERY)
@JsonInclude(value = JsonInclude.Include.USE_DEFAULTS)
public String getQuery() {
return query;
}
public void setQuery(String query) {
this.query = query;
}
/**
* A container for additional, undeclared properties. This is a holder for any undeclared
* properties as specified with the 'additionalProperties' keyword in the OAS document.
*/
private Map additionalProperties;
/**
* Set the additional (undeclared) property with the specified name and value. If the property
* does not already exist, create it otherwise replace it.
*
* @param key The arbitrary key to set
* @param value The associated value
* @return SecurityMonitoringStandardRuleQuery
*/
@JsonAnySetter
public SecurityMonitoringStandardRuleQuery putAdditionalProperty(String key, Object value) {
if (this.additionalProperties == null) {
this.additionalProperties = new HashMap();
}
this.additionalProperties.put(key, value);
return this;
}
/**
* Return the additional (undeclared) property.
*
* @return The additional properties
*/
@JsonAnyGetter
public Map getAdditionalProperties() {
return additionalProperties;
}
/**
* Return the additional (undeclared) property with the specified name.
*
* @param key The arbitrary key to get
* @return The specific additional property for the given key
*/
public Object getAdditionalProperty(String key) {
if (this.additionalProperties == null) {
return null;
}
return this.additionalProperties.get(key);
}
/** Return true if this SecurityMonitoringStandardRuleQuery object is equal to o. */
@Override
public boolean equals(Object o) {
if (this == o) {
return true;
}
if (o == null || getClass() != o.getClass()) {
return false;
}
SecurityMonitoringStandardRuleQuery securityMonitoringStandardRuleQuery =
(SecurityMonitoringStandardRuleQuery) o;
return Objects.equals(this.aggregation, securityMonitoringStandardRuleQuery.aggregation)
&& Objects.equals(this.distinctFields, securityMonitoringStandardRuleQuery.distinctFields)
&& Objects.equals(this.groupByFields, securityMonitoringStandardRuleQuery.groupByFields)
&& Objects.equals(
this.hasOptionalGroupByFields,
securityMonitoringStandardRuleQuery.hasOptionalGroupByFields)
&& Objects.equals(this.metric, securityMonitoringStandardRuleQuery.metric)
&& Objects.equals(this.metrics, securityMonitoringStandardRuleQuery.metrics)
&& Objects.equals(this.name, securityMonitoringStandardRuleQuery.name)
&& Objects.equals(this.query, securityMonitoringStandardRuleQuery.query)
&& Objects.equals(
this.additionalProperties, securityMonitoringStandardRuleQuery.additionalProperties);
}
@Override
public int hashCode() {
return Objects.hash(
aggregation,
distinctFields,
groupByFields,
hasOptionalGroupByFields,
metric,
metrics,
name,
query,
additionalProperties);
}
@Override
public String toString() {
StringBuilder sb = new StringBuilder();
sb.append("class SecurityMonitoringStandardRuleQuery {\n");
sb.append(" aggregation: ").append(toIndentedString(aggregation)).append("\n");
sb.append(" distinctFields: ").append(toIndentedString(distinctFields)).append("\n");
sb.append(" groupByFields: ").append(toIndentedString(groupByFields)).append("\n");
sb.append(" hasOptionalGroupByFields: ")
.append(toIndentedString(hasOptionalGroupByFields))
.append("\n");
sb.append(" metric: ").append(toIndentedString(metric)).append("\n");
sb.append(" metrics: ").append(toIndentedString(metrics)).append("\n");
sb.append(" name: ").append(toIndentedString(name)).append("\n");
sb.append(" query: ").append(toIndentedString(query)).append("\n");
sb.append(" additionalProperties: ")
.append(toIndentedString(additionalProperties))
.append("\n");
sb.append('}');
return sb.toString();
}
/**
* Convert the given object to string with each line indented by 4 spaces (except the first line).
*/
private String toIndentedString(Object o) {
if (o == null) {
return "null";
}
return o.toString().replace("\n", "\n ");
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy