com.amazonaws.services.inspector2.model.LambdaFunctionAggregation Maven / Gradle / Ivy
Show all versions of aws-java-sdk-inspector2 Show documentation
/*
* Copyright 2019-2024 Amazon.com, Inc. or its affiliates. All Rights Reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License"). You may not use this file except in compliance with
* the License. A copy of the License is located at
*
* http://aws.amazon.com/apache2.0
*
* or in the "license" file accompanying this file. This file is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR
* CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions
* and limitations under the License.
*/
package com.amazonaws.services.inspector2.model;
import java.io.Serializable;
import javax.annotation.Generated;
import com.amazonaws.protocol.StructuredPojo;
import com.amazonaws.protocol.ProtocolMarshaller;
/**
*
* The details that define a findings aggregation based on Amazon Web Services Lambda functions.
*
*
* @see AWS API Documentation
*/
@Generated("com.amazonaws:aws-java-sdk-code-generator")
public class LambdaFunctionAggregation implements Serializable, Cloneable, StructuredPojo {
/**
*
* The Amazon Web Services Lambda function names to include in the aggregation results.
*
*/
private java.util.List functionNames;
/**
*
* The tags to include in the aggregation results.
*
*/
private java.util.List functionTags;
/**
*
* The resource IDs to include in the aggregation results.
*
*/
private java.util.List resourceIds;
/**
*
* Returns findings aggregated by Amazon Web Services Lambda function runtime environments.
*
*/
private java.util.List runtimes;
/**
*
* The finding severity to use for sorting the results.
*
*/
private String sortBy;
/**
*
* The order to use for sorting the results.
*
*/
private String sortOrder;
/**
*
* The Amazon Web Services Lambda function names to include in the aggregation results.
*
*
* @return The Amazon Web Services Lambda function names to include in the aggregation results.
*/
public java.util.List getFunctionNames() {
return functionNames;
}
/**
*
* The Amazon Web Services Lambda function names to include in the aggregation results.
*
*
* @param functionNames
* The Amazon Web Services Lambda function names to include in the aggregation results.
*/
public void setFunctionNames(java.util.Collection functionNames) {
if (functionNames == null) {
this.functionNames = null;
return;
}
this.functionNames = new java.util.ArrayList(functionNames);
}
/**
*
* The Amazon Web Services Lambda function names to include in the aggregation results.
*
*
* NOTE: This method appends the values to the existing list (if any). Use
* {@link #setFunctionNames(java.util.Collection)} or {@link #withFunctionNames(java.util.Collection)} if you want
* to override the existing values.
*
*
* @param functionNames
* The Amazon Web Services Lambda function names to include in the aggregation results.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public LambdaFunctionAggregation withFunctionNames(StringFilter... functionNames) {
if (this.functionNames == null) {
setFunctionNames(new java.util.ArrayList(functionNames.length));
}
for (StringFilter ele : functionNames) {
this.functionNames.add(ele);
}
return this;
}
/**
*
* The Amazon Web Services Lambda function names to include in the aggregation results.
*
*
* @param functionNames
* The Amazon Web Services Lambda function names to include in the aggregation results.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public LambdaFunctionAggregation withFunctionNames(java.util.Collection functionNames) {
setFunctionNames(functionNames);
return this;
}
/**
*
* The tags to include in the aggregation results.
*
*
* @return The tags to include in the aggregation results.
*/
public java.util.List getFunctionTags() {
return functionTags;
}
/**
*
* The tags to include in the aggregation results.
*
*
* @param functionTags
* The tags to include in the aggregation results.
*/
public void setFunctionTags(java.util.Collection functionTags) {
if (functionTags == null) {
this.functionTags = null;
return;
}
this.functionTags = new java.util.ArrayList(functionTags);
}
/**
*
* The tags to include in the aggregation results.
*
*
* NOTE: This method appends the values to the existing list (if any). Use
* {@link #setFunctionTags(java.util.Collection)} or {@link #withFunctionTags(java.util.Collection)} if you want to
* override the existing values.
*
*
* @param functionTags
* The tags to include in the aggregation results.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public LambdaFunctionAggregation withFunctionTags(MapFilter... functionTags) {
if (this.functionTags == null) {
setFunctionTags(new java.util.ArrayList(functionTags.length));
}
for (MapFilter ele : functionTags) {
this.functionTags.add(ele);
}
return this;
}
/**
*
* The tags to include in the aggregation results.
*
*
* @param functionTags
* The tags to include in the aggregation results.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public LambdaFunctionAggregation withFunctionTags(java.util.Collection functionTags) {
setFunctionTags(functionTags);
return this;
}
/**
*
* The resource IDs to include in the aggregation results.
*
*
* @return The resource IDs to include in the aggregation results.
*/
public java.util.List getResourceIds() {
return resourceIds;
}
/**
*
* The resource IDs to include in the aggregation results.
*
*
* @param resourceIds
* The resource IDs to include in the aggregation results.
*/
public void setResourceIds(java.util.Collection resourceIds) {
if (resourceIds == null) {
this.resourceIds = null;
return;
}
this.resourceIds = new java.util.ArrayList(resourceIds);
}
/**
*
* The resource IDs to include in the aggregation results.
*
*
* NOTE: This method appends the values to the existing list (if any). Use
* {@link #setResourceIds(java.util.Collection)} or {@link #withResourceIds(java.util.Collection)} if you want to
* override the existing values.
*
*
* @param resourceIds
* The resource IDs to include in the aggregation results.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public LambdaFunctionAggregation withResourceIds(StringFilter... resourceIds) {
if (this.resourceIds == null) {
setResourceIds(new java.util.ArrayList(resourceIds.length));
}
for (StringFilter ele : resourceIds) {
this.resourceIds.add(ele);
}
return this;
}
/**
*
* The resource IDs to include in the aggregation results.
*
*
* @param resourceIds
* The resource IDs to include in the aggregation results.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public LambdaFunctionAggregation withResourceIds(java.util.Collection resourceIds) {
setResourceIds(resourceIds);
return this;
}
/**
*
* Returns findings aggregated by Amazon Web Services Lambda function runtime environments.
*
*
* @return Returns findings aggregated by Amazon Web Services Lambda function runtime environments.
*/
public java.util.List getRuntimes() {
return runtimes;
}
/**
*
* Returns findings aggregated by Amazon Web Services Lambda function runtime environments.
*
*
* @param runtimes
* Returns findings aggregated by Amazon Web Services Lambda function runtime environments.
*/
public void setRuntimes(java.util.Collection runtimes) {
if (runtimes == null) {
this.runtimes = null;
return;
}
this.runtimes = new java.util.ArrayList(runtimes);
}
/**
*
* Returns findings aggregated by Amazon Web Services Lambda function runtime environments.
*
*
* NOTE: This method appends the values to the existing list (if any). Use
* {@link #setRuntimes(java.util.Collection)} or {@link #withRuntimes(java.util.Collection)} if you want to override
* the existing values.
*
*
* @param runtimes
* Returns findings aggregated by Amazon Web Services Lambda function runtime environments.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public LambdaFunctionAggregation withRuntimes(StringFilter... runtimes) {
if (this.runtimes == null) {
setRuntimes(new java.util.ArrayList(runtimes.length));
}
for (StringFilter ele : runtimes) {
this.runtimes.add(ele);
}
return this;
}
/**
*
* Returns findings aggregated by Amazon Web Services Lambda function runtime environments.
*
*
* @param runtimes
* Returns findings aggregated by Amazon Web Services Lambda function runtime environments.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public LambdaFunctionAggregation withRuntimes(java.util.Collection runtimes) {
setRuntimes(runtimes);
return this;
}
/**
*
* The finding severity to use for sorting the results.
*
*
* @param sortBy
* The finding severity to use for sorting the results.
* @see LambdaFunctionSortBy
*/
public void setSortBy(String sortBy) {
this.sortBy = sortBy;
}
/**
*
* The finding severity to use for sorting the results.
*
*
* @return The finding severity to use for sorting the results.
* @see LambdaFunctionSortBy
*/
public String getSortBy() {
return this.sortBy;
}
/**
*
* The finding severity to use for sorting the results.
*
*
* @param sortBy
* The finding severity to use for sorting the results.
* @return Returns a reference to this object so that method calls can be chained together.
* @see LambdaFunctionSortBy
*/
public LambdaFunctionAggregation withSortBy(String sortBy) {
setSortBy(sortBy);
return this;
}
/**
*
* The finding severity to use for sorting the results.
*
*
* @param sortBy
* The finding severity to use for sorting the results.
* @return Returns a reference to this object so that method calls can be chained together.
* @see LambdaFunctionSortBy
*/
public LambdaFunctionAggregation withSortBy(LambdaFunctionSortBy sortBy) {
this.sortBy = sortBy.toString();
return this;
}
/**
*
* The order to use for sorting the results.
*
*
* @param sortOrder
* The order to use for sorting the results.
* @see SortOrder
*/
public void setSortOrder(String sortOrder) {
this.sortOrder = sortOrder;
}
/**
*
* The order to use for sorting the results.
*
*
* @return The order to use for sorting the results.
* @see SortOrder
*/
public String getSortOrder() {
return this.sortOrder;
}
/**
*
* The order to use for sorting the results.
*
*
* @param sortOrder
* The order to use for sorting the results.
* @return Returns a reference to this object so that method calls can be chained together.
* @see SortOrder
*/
public LambdaFunctionAggregation withSortOrder(String sortOrder) {
setSortOrder(sortOrder);
return this;
}
/**
*
* The order to use for sorting the results.
*
*
* @param sortOrder
* The order to use for sorting the results.
* @return Returns a reference to this object so that method calls can be chained together.
* @see SortOrder
*/
public LambdaFunctionAggregation withSortOrder(SortOrder sortOrder) {
this.sortOrder = sortOrder.toString();
return this;
}
/**
* Returns a string representation of this object. This is useful for testing and debugging. Sensitive data will be
* redacted from this string using a placeholder value.
*
* @return A string representation of this object.
*
* @see java.lang.Object#toString()
*/
@Override
public String toString() {
StringBuilder sb = new StringBuilder();
sb.append("{");
if (getFunctionNames() != null)
sb.append("FunctionNames: ").append(getFunctionNames()).append(",");
if (getFunctionTags() != null)
sb.append("FunctionTags: ").append(getFunctionTags()).append(",");
if (getResourceIds() != null)
sb.append("ResourceIds: ").append(getResourceIds()).append(",");
if (getRuntimes() != null)
sb.append("Runtimes: ").append(getRuntimes()).append(",");
if (getSortBy() != null)
sb.append("SortBy: ").append(getSortBy()).append(",");
if (getSortOrder() != null)
sb.append("SortOrder: ").append(getSortOrder());
sb.append("}");
return sb.toString();
}
@Override
public boolean equals(Object obj) {
if (this == obj)
return true;
if (obj == null)
return false;
if (obj instanceof LambdaFunctionAggregation == false)
return false;
LambdaFunctionAggregation other = (LambdaFunctionAggregation) obj;
if (other.getFunctionNames() == null ^ this.getFunctionNames() == null)
return false;
if (other.getFunctionNames() != null && other.getFunctionNames().equals(this.getFunctionNames()) == false)
return false;
if (other.getFunctionTags() == null ^ this.getFunctionTags() == null)
return false;
if (other.getFunctionTags() != null && other.getFunctionTags().equals(this.getFunctionTags()) == false)
return false;
if (other.getResourceIds() == null ^ this.getResourceIds() == null)
return false;
if (other.getResourceIds() != null && other.getResourceIds().equals(this.getResourceIds()) == false)
return false;
if (other.getRuntimes() == null ^ this.getRuntimes() == null)
return false;
if (other.getRuntimes() != null && other.getRuntimes().equals(this.getRuntimes()) == false)
return false;
if (other.getSortBy() == null ^ this.getSortBy() == null)
return false;
if (other.getSortBy() != null && other.getSortBy().equals(this.getSortBy()) == false)
return false;
if (other.getSortOrder() == null ^ this.getSortOrder() == null)
return false;
if (other.getSortOrder() != null && other.getSortOrder().equals(this.getSortOrder()) == false)
return false;
return true;
}
@Override
public int hashCode() {
final int prime = 31;
int hashCode = 1;
hashCode = prime * hashCode + ((getFunctionNames() == null) ? 0 : getFunctionNames().hashCode());
hashCode = prime * hashCode + ((getFunctionTags() == null) ? 0 : getFunctionTags().hashCode());
hashCode = prime * hashCode + ((getResourceIds() == null) ? 0 : getResourceIds().hashCode());
hashCode = prime * hashCode + ((getRuntimes() == null) ? 0 : getRuntimes().hashCode());
hashCode = prime * hashCode + ((getSortBy() == null) ? 0 : getSortBy().hashCode());
hashCode = prime * hashCode + ((getSortOrder() == null) ? 0 : getSortOrder().hashCode());
return hashCode;
}
@Override
public LambdaFunctionAggregation clone() {
try {
return (LambdaFunctionAggregation) super.clone();
} catch (CloneNotSupportedException e) {
throw new IllegalStateException("Got a CloneNotSupportedException from Object.clone() " + "even though we're Cloneable!", e);
}
}
@com.amazonaws.annotation.SdkInternalApi
@Override
public void marshall(ProtocolMarshaller protocolMarshaller) {
com.amazonaws.services.inspector2.model.transform.LambdaFunctionAggregationMarshaller.getInstance().marshall(this, protocolMarshaller);
}
}