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

com.amazonaws.services.securityhub.model.FindingProviderFields Maven / Gradle / Ivy

Go to download

The AWS Java SDK for AWS SecurityHub module holds the client classes that are used for communicating with AWS SecurityHub Service

The newest version!
/*
 * 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.securityhub.model;

import java.io.Serializable;
import javax.annotation.Generated;
import com.amazonaws.protocol.StructuredPojo;
import com.amazonaws.protocol.ProtocolMarshaller;

/**
 * 

* In a * BatchImportFindings request, finding providers use FindingProviderFields to provide * and update values for the following fields: *

*
    *
  • *

    * Confidence *

    *
  • *
  • *

    * Criticality *

    *
  • *
  • *

    * RelatedFindings *

    *
  • *
  • *

    * Severity *

    *
  • *
  • *

    * Types *

    *
  • *
*

* The preceding fields are nested under the FindingProviderFields object, but also have analogues of the * same name as top-level ASFF fields. When a new finding is sent to Security Hub by a finding provider, Security Hub * populates the FindingProviderFields object automatically, if it is empty, based on the corresponding * top-level fields. *

*

* Finding providers can update FindingProviderFields only by using the BatchImportFindings * operation. Finding providers can't update this object with the * BatchUpdateFindings operation. Customers can update the top-level fields by using the * BatchUpdateFindings operation. Customers can't update FindingProviderFields. *

*

* For information about how Security Hub handles updates from BatchImportFindings to * FindingProviderFields and to the corresponding top-level attributes, see Using FindingProviderFields in the Security Hub User Guide. *

*

* * @see AWS * API Documentation */ @Generated("com.amazonaws:aws-java-sdk-code-generator") public class FindingProviderFields implements Serializable, Cloneable, StructuredPojo { /** *

* A finding's confidence. Confidence is defined as the likelihood that a finding accurately identifies the behavior * or issue that it was intended to identify. *

*

* Confidence is scored on a 0-100 basis using a ratio scale, where 0 means zero percent confidence and 100 means * 100 percent confidence. *

*/ private Integer confidence; /** *

* The level of importance assigned to the resources associated with the finding. *

*

* A score of 0 means that the underlying resources have no criticality, and a score of 100 is reserved for the most * critical resources. *

*/ private Integer criticality; /** *

* A list of findings that are related to the current finding. *

*/ private java.util.List relatedFindings; /** *

* The severity of a finding. *

*/ private FindingProviderSeverity severity; /** *

* One or more finding types in the format of namespace/category/classifier that classify a finding. *

*

* Valid namespace values are: Software and Configuration Checks | TTPs | Effects | Unusual Behaviors | Sensitive * Data Identifications *

*/ private java.util.List types; /** *

* A finding's confidence. Confidence is defined as the likelihood that a finding accurately identifies the behavior * or issue that it was intended to identify. *

*

* Confidence is scored on a 0-100 basis using a ratio scale, where 0 means zero percent confidence and 100 means * 100 percent confidence. *

* * @param confidence * A finding's confidence. Confidence is defined as the likelihood that a finding accurately identifies the * behavior or issue that it was intended to identify.

*

* Confidence is scored on a 0-100 basis using a ratio scale, where 0 means zero percent confidence and 100 * means 100 percent confidence. */ public void setConfidence(Integer confidence) { this.confidence = confidence; } /** *

* A finding's confidence. Confidence is defined as the likelihood that a finding accurately identifies the behavior * or issue that it was intended to identify. *

*

* Confidence is scored on a 0-100 basis using a ratio scale, where 0 means zero percent confidence and 100 means * 100 percent confidence. *

* * @return A finding's confidence. Confidence is defined as the likelihood that a finding accurately identifies the * behavior or issue that it was intended to identify.

*

* Confidence is scored on a 0-100 basis using a ratio scale, where 0 means zero percent confidence and 100 * means 100 percent confidence. */ public Integer getConfidence() { return this.confidence; } /** *

* A finding's confidence. Confidence is defined as the likelihood that a finding accurately identifies the behavior * or issue that it was intended to identify. *

*

* Confidence is scored on a 0-100 basis using a ratio scale, where 0 means zero percent confidence and 100 means * 100 percent confidence. *

* * @param confidence * A finding's confidence. Confidence is defined as the likelihood that a finding accurately identifies the * behavior or issue that it was intended to identify.

*

* Confidence is scored on a 0-100 basis using a ratio scale, where 0 means zero percent confidence and 100 * means 100 percent confidence. * @return Returns a reference to this object so that method calls can be chained together. */ public FindingProviderFields withConfidence(Integer confidence) { setConfidence(confidence); return this; } /** *

* The level of importance assigned to the resources associated with the finding. *

*

* A score of 0 means that the underlying resources have no criticality, and a score of 100 is reserved for the most * critical resources. *

* * @param criticality * The level of importance assigned to the resources associated with the finding.

*

* A score of 0 means that the underlying resources have no criticality, and a score of 100 is reserved for * the most critical resources. */ public void setCriticality(Integer criticality) { this.criticality = criticality; } /** *

* The level of importance assigned to the resources associated with the finding. *

*

* A score of 0 means that the underlying resources have no criticality, and a score of 100 is reserved for the most * critical resources. *

* * @return The level of importance assigned to the resources associated with the finding.

*

* A score of 0 means that the underlying resources have no criticality, and a score of 100 is reserved for * the most critical resources. */ public Integer getCriticality() { return this.criticality; } /** *

* The level of importance assigned to the resources associated with the finding. *

*

* A score of 0 means that the underlying resources have no criticality, and a score of 100 is reserved for the most * critical resources. *

* * @param criticality * The level of importance assigned to the resources associated with the finding.

*

* A score of 0 means that the underlying resources have no criticality, and a score of 100 is reserved for * the most critical resources. * @return Returns a reference to this object so that method calls can be chained together. */ public FindingProviderFields withCriticality(Integer criticality) { setCriticality(criticality); return this; } /** *

* A list of findings that are related to the current finding. *

* * @return A list of findings that are related to the current finding. */ public java.util.List getRelatedFindings() { return relatedFindings; } /** *

* A list of findings that are related to the current finding. *

* * @param relatedFindings * A list of findings that are related to the current finding. */ public void setRelatedFindings(java.util.Collection relatedFindings) { if (relatedFindings == null) { this.relatedFindings = null; return; } this.relatedFindings = new java.util.ArrayList(relatedFindings); } /** *

* A list of findings that are related to the current finding. *

*

* NOTE: This method appends the values to the existing list (if any). Use * {@link #setRelatedFindings(java.util.Collection)} or {@link #withRelatedFindings(java.util.Collection)} if you * want to override the existing values. *

* * @param relatedFindings * A list of findings that are related to the current finding. * @return Returns a reference to this object so that method calls can be chained together. */ public FindingProviderFields withRelatedFindings(RelatedFinding... relatedFindings) { if (this.relatedFindings == null) { setRelatedFindings(new java.util.ArrayList(relatedFindings.length)); } for (RelatedFinding ele : relatedFindings) { this.relatedFindings.add(ele); } return this; } /** *

* A list of findings that are related to the current finding. *

* * @param relatedFindings * A list of findings that are related to the current finding. * @return Returns a reference to this object so that method calls can be chained together. */ public FindingProviderFields withRelatedFindings(java.util.Collection relatedFindings) { setRelatedFindings(relatedFindings); return this; } /** *

* The severity of a finding. *

* * @param severity * The severity of a finding. */ public void setSeverity(FindingProviderSeverity severity) { this.severity = severity; } /** *

* The severity of a finding. *

* * @return The severity of a finding. */ public FindingProviderSeverity getSeverity() { return this.severity; } /** *

* The severity of a finding. *

* * @param severity * The severity of a finding. * @return Returns a reference to this object so that method calls can be chained together. */ public FindingProviderFields withSeverity(FindingProviderSeverity severity) { setSeverity(severity); return this; } /** *

* One or more finding types in the format of namespace/category/classifier that classify a finding. *

*

* Valid namespace values are: Software and Configuration Checks | TTPs | Effects | Unusual Behaviors | Sensitive * Data Identifications *

* * @return One or more finding types in the format of namespace/category/classifier that classify a * finding.

*

* Valid namespace values are: Software and Configuration Checks | TTPs | Effects | Unusual Behaviors | * Sensitive Data Identifications */ public java.util.List getTypes() { return types; } /** *

* One or more finding types in the format of namespace/category/classifier that classify a finding. *

*

* Valid namespace values are: Software and Configuration Checks | TTPs | Effects | Unusual Behaviors | Sensitive * Data Identifications *

* * @param types * One or more finding types in the format of namespace/category/classifier that classify a * finding.

*

* Valid namespace values are: Software and Configuration Checks | TTPs | Effects | Unusual Behaviors | * Sensitive Data Identifications */ public void setTypes(java.util.Collection types) { if (types == null) { this.types = null; return; } this.types = new java.util.ArrayList(types); } /** *

* One or more finding types in the format of namespace/category/classifier that classify a finding. *

*

* Valid namespace values are: Software and Configuration Checks | TTPs | Effects | Unusual Behaviors | Sensitive * Data Identifications *

*

* NOTE: This method appends the values to the existing list (if any). Use * {@link #setTypes(java.util.Collection)} or {@link #withTypes(java.util.Collection)} if you want to override the * existing values. *

* * @param types * One or more finding types in the format of namespace/category/classifier that classify a * finding.

*

* Valid namespace values are: Software and Configuration Checks | TTPs | Effects | Unusual Behaviors | * Sensitive Data Identifications * @return Returns a reference to this object so that method calls can be chained together. */ public FindingProviderFields withTypes(String... types) { if (this.types == null) { setTypes(new java.util.ArrayList(types.length)); } for (String ele : types) { this.types.add(ele); } return this; } /** *

* One or more finding types in the format of namespace/category/classifier that classify a finding. *

*

* Valid namespace values are: Software and Configuration Checks | TTPs | Effects | Unusual Behaviors | Sensitive * Data Identifications *

* * @param types * One or more finding types in the format of namespace/category/classifier that classify a * finding.

*

* Valid namespace values are: Software and Configuration Checks | TTPs | Effects | Unusual Behaviors | * Sensitive Data Identifications * @return Returns a reference to this object so that method calls can be chained together. */ public FindingProviderFields withTypes(java.util.Collection types) { setTypes(types); 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 (getConfidence() != null) sb.append("Confidence: ").append(getConfidence()).append(","); if (getCriticality() != null) sb.append("Criticality: ").append(getCriticality()).append(","); if (getRelatedFindings() != null) sb.append("RelatedFindings: ").append(getRelatedFindings()).append(","); if (getSeverity() != null) sb.append("Severity: ").append(getSeverity()).append(","); if (getTypes() != null) sb.append("Types: ").append(getTypes()); sb.append("}"); return sb.toString(); } @Override public boolean equals(Object obj) { if (this == obj) return true; if (obj == null) return false; if (obj instanceof FindingProviderFields == false) return false; FindingProviderFields other = (FindingProviderFields) obj; if (other.getConfidence() == null ^ this.getConfidence() == null) return false; if (other.getConfidence() != null && other.getConfidence().equals(this.getConfidence()) == false) return false; if (other.getCriticality() == null ^ this.getCriticality() == null) return false; if (other.getCriticality() != null && other.getCriticality().equals(this.getCriticality()) == false) return false; if (other.getRelatedFindings() == null ^ this.getRelatedFindings() == null) return false; if (other.getRelatedFindings() != null && other.getRelatedFindings().equals(this.getRelatedFindings()) == false) return false; if (other.getSeverity() == null ^ this.getSeverity() == null) return false; if (other.getSeverity() != null && other.getSeverity().equals(this.getSeverity()) == false) return false; if (other.getTypes() == null ^ this.getTypes() == null) return false; if (other.getTypes() != null && other.getTypes().equals(this.getTypes()) == false) return false; return true; } @Override public int hashCode() { final int prime = 31; int hashCode = 1; hashCode = prime * hashCode + ((getConfidence() == null) ? 0 : getConfidence().hashCode()); hashCode = prime * hashCode + ((getCriticality() == null) ? 0 : getCriticality().hashCode()); hashCode = prime * hashCode + ((getRelatedFindings() == null) ? 0 : getRelatedFindings().hashCode()); hashCode = prime * hashCode + ((getSeverity() == null) ? 0 : getSeverity().hashCode()); hashCode = prime * hashCode + ((getTypes() == null) ? 0 : getTypes().hashCode()); return hashCode; } @Override public FindingProviderFields clone() { try { return (FindingProviderFields) 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.securityhub.model.transform.FindingProviderFieldsMarshaller.getInstance().marshall(this, protocolMarshaller); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy