com.amazonaws.services.securityhub.model.AwsSecurityFinding Maven / Gradle / Ivy
/*
* Copyright 2018-2023 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;
/**
*
* Provides a consistent format for Security Hub findings. AwsSecurityFinding
format allows you to share
* findings between Amazon Web Services security services and third-party solutions.
*
*
*
* A finding is a potential security issue generated either by Amazon Web Services services or by the integrated
* third-party solutions and standards checks.
*
*
*
* @see AWS API
* Documentation
*/
@Generated("com.amazonaws:aws-java-sdk-code-generator")
public class AwsSecurityFinding implements Serializable, Cloneable, StructuredPojo {
/**
*
* The schema version that a finding is formatted for.
*
*/
private String schemaVersion;
/**
*
* The security findings provider-specific identifier for a finding.
*
*/
private String id;
/**
*
* The ARN generated by Security Hub that uniquely identifies a product that generates findings. This can be the ARN
* for a third-party product that is integrated with Security Hub, or the ARN for a custom integration.
*
*/
private String productArn;
/**
*
* The name of the product that generated the finding.
*
*
* Security Hub populates this attribute automatically for each finding. You cannot update this attribute with
* BatchImportFindings
or BatchUpdateFindings
. The exception to this is a custom
* integration.
*
*
* When you use the Security Hub console or API to filter findings by product name, you use this attribute.
*
*/
private String productName;
/**
*
* The name of the company for the product that generated the finding.
*
*
* Security Hub populates this attribute automatically for each finding. You cannot update this attribute with
* BatchImportFindings
or BatchUpdateFindings
. The exception to this is a custom
* integration.
*
*
* When you use the Security Hub console or API to filter findings by company name, you use this attribute.
*
*/
private String companyName;
/**
*
* The Region from which the finding was generated.
*
*
* Security Hub populates this attribute automatically for each finding. You cannot update it using
* BatchImportFindings
or BatchUpdateFindings
.
*
*/
private String region;
/**
*
* The identifier for the solution-specific component (a discrete unit of logic) that generated a finding. In
* various security findings providers' solutions, this generator can be called a rule, a check, a detector, a
* plugin, etc.
*
*/
private String generatorId;
/**
*
* The Amazon Web Services account ID that a finding is generated in.
*
*/
private String awsAccountId;
/**
*
* 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;
/**
*
* Indicates when the security findings provider first observed the potential security issue that a finding
* captured.
*
*
* Uses the date-time
format specified in RFC
* 3339 section 5.6, Internet Date/Time Format. The value cannot contain spaces, and date and time should be
* separated by T
. For example, 2020-03-22T13:22:13.933Z
.
*
*/
private String firstObservedAt;
/**
*
* Indicates when the security findings provider most recently observed the potential security issue that a finding
* captured.
*
*
* Uses the date-time
format specified in RFC
* 3339 section 5.6, Internet Date/Time Format. The value cannot contain spaces, and date and time should be
* separated by T
. For example, 2020-03-22T13:22:13.933Z
.
*
*/
private String lastObservedAt;
/**
*
* Indicates when the security findings provider created the potential security issue that a finding captured.
*
*
* Uses the date-time
format specified in RFC
* 3339 section 5.6, Internet Date/Time Format. The value cannot contain spaces, and date and time should be
* separated by T
. For example, 2020-03-22T13:22:13.933Z
.
*
*/
private String createdAt;
/**
*
* Indicates when the security findings provider last updated the finding record.
*
*
* Uses the date-time
format specified in RFC
* 3339 section 5.6, Internet Date/Time Format. The value cannot contain spaces, and date and time should be
* separated by T
. For example, 2020-03-22T13:22:13.933Z
.
*
*/
private String updatedAt;
/**
*
* A finding's severity.
*
*/
private Severity severity;
/**
*
* 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 finding's title.
*
*
*
* In this release, Title
is a required property.
*
*
*/
private String title;
/**
*
* A finding's description.
*
*
*
* In this release, Description
is a required property.
*
*
*/
private String description;
/**
*
* A data type that describes the remediation options for a finding.
*
*/
private Remediation remediation;
/**
*
* A URL that links to a page about the current finding in the security findings provider's solution.
*
*/
private String sourceUrl;
/**
*
* A data type where security findings providers can include additional solution-specific details that aren't part
* of the defined AwsSecurityFinding
format.
*
*
* Can contain up to 50 key-value pairs. For each key-value pair, the key can contain up to 128 characters, and the
* value can contain up to 2048 characters.
*
*/
private java.util.Map productFields;
/**
*
* A list of name/value string pairs associated with the finding. These are custom, user-defined fields added to a
* finding.
*
*/
private java.util.Map userDefinedFields;
/**
*
* A list of malware related to a finding.
*
*/
private java.util.List malware;
/**
*
* The details of network-related information about a finding.
*
*/
private Network network;
/**
*
* Provides information about a network path that is relevant to a finding. Each entry under
* NetworkPath
represents a component of that path.
*
*/
private java.util.List networkPath;
/**
*
* The details of process-related information about a finding.
*
*/
private ProcessDetails process;
/**
*
* Details about the threat detected in a security finding and the file paths that were affected by the threat.
*
*/
private java.util.List threats;
/**
*
* Threat intelligence details related to a finding.
*
*/
private java.util.List threatIntelIndicators;
/**
*
* A set of resource data types that describe the resources that the finding refers to.
*
*/
private java.util.List resources;
/**
*
* This data type is exclusive to findings that are generated as the result of a check run against a specific rule
* in a supported security standard, such as CIS Amazon Web Services Foundations. Contains security standard-related
* finding details.
*
*/
private Compliance compliance;
/**
*
* Indicates the veracity of a finding.
*
*/
private String verificationState;
/**
*
* The workflow state of a finding.
*
*/
private String workflowState;
/**
*
* Provides information about the status of the investigation into a finding.
*
*/
private Workflow workflow;
/**
*
* The record state of a finding.
*
*/
private String recordState;
/**
*
* A list of related findings.
*
*/
private java.util.List relatedFindings;
/**
*
* A user-defined note added to a finding.
*
*/
private Note note;
/**
*
* Provides a list of vulnerabilities associated with the findings.
*
*/
private java.util.List vulnerabilities;
/**
*
* Provides an overview of the patch compliance status for an instance against a selected compliance standard.
*
*/
private PatchSummary patchSummary;
/**
*
* Provides details about an action that affects or that was taken on a resource.
*
*/
private Action action;
/**
*
* In a BatchImportFindings
request, finding providers use FindingProviderFields
to
* provide and update their own values for confidence, criticality, related findings, severity, and types.
*
*/
private FindingProviderFields findingProviderFields;
/**
*
* Indicates whether the finding is a sample finding.
*
*/
private Boolean sample;
/**
*
* Provides metadata for the Amazon CodeGuru detector associated with a finding. This field pertains to findings
* that relate to Lambda functions. Amazon Inspector identifies policy violations and vulnerabilities in Lambda
* function code based on internal detectors developed in collaboration with Amazon CodeGuru. Security Hub receives
* those findings.
*
*/
private GeneratorDetails generatorDetails;
/**
*
* The schema version that a finding is formatted for.
*
*
* @param schemaVersion
* The schema version that a finding is formatted for.
*/
public void setSchemaVersion(String schemaVersion) {
this.schemaVersion = schemaVersion;
}
/**
*
* The schema version that a finding is formatted for.
*
*
* @return The schema version that a finding is formatted for.
*/
public String getSchemaVersion() {
return this.schemaVersion;
}
/**
*
* The schema version that a finding is formatted for.
*
*
* @param schemaVersion
* The schema version that a finding is formatted for.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public AwsSecurityFinding withSchemaVersion(String schemaVersion) {
setSchemaVersion(schemaVersion);
return this;
}
/**
*
* The security findings provider-specific identifier for a finding.
*
*
* @param id
* The security findings provider-specific identifier for a finding.
*/
public void setId(String id) {
this.id = id;
}
/**
*
* The security findings provider-specific identifier for a finding.
*
*
* @return The security findings provider-specific identifier for a finding.
*/
public String getId() {
return this.id;
}
/**
*
* The security findings provider-specific identifier for a finding.
*
*
* @param id
* The security findings provider-specific identifier for a finding.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public AwsSecurityFinding withId(String id) {
setId(id);
return this;
}
/**
*
* The ARN generated by Security Hub that uniquely identifies a product that generates findings. This can be the ARN
* for a third-party product that is integrated with Security Hub, or the ARN for a custom integration.
*
*
* @param productArn
* The ARN generated by Security Hub that uniquely identifies a product that generates findings. This can be
* the ARN for a third-party product that is integrated with Security Hub, or the ARN for a custom
* integration.
*/
public void setProductArn(String productArn) {
this.productArn = productArn;
}
/**
*
* The ARN generated by Security Hub that uniquely identifies a product that generates findings. This can be the ARN
* for a third-party product that is integrated with Security Hub, or the ARN for a custom integration.
*
*
* @return The ARN generated by Security Hub that uniquely identifies a product that generates findings. This can be
* the ARN for a third-party product that is integrated with Security Hub, or the ARN for a custom
* integration.
*/
public String getProductArn() {
return this.productArn;
}
/**
*
* The ARN generated by Security Hub that uniquely identifies a product that generates findings. This can be the ARN
* for a third-party product that is integrated with Security Hub, or the ARN for a custom integration.
*
*
* @param productArn
* The ARN generated by Security Hub that uniquely identifies a product that generates findings. This can be
* the ARN for a third-party product that is integrated with Security Hub, or the ARN for a custom
* integration.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public AwsSecurityFinding withProductArn(String productArn) {
setProductArn(productArn);
return this;
}
/**
*
* The name of the product that generated the finding.
*
*
* Security Hub populates this attribute automatically for each finding. You cannot update this attribute with
* BatchImportFindings
or BatchUpdateFindings
. The exception to this is a custom
* integration.
*
*
* When you use the Security Hub console or API to filter findings by product name, you use this attribute.
*
*
* @param productName
* The name of the product that generated the finding.
*
* Security Hub populates this attribute automatically for each finding. You cannot update this attribute
* with BatchImportFindings
or BatchUpdateFindings
. The exception to this is a
* custom integration.
*
*
* When you use the Security Hub console or API to filter findings by product name, you use this attribute.
*/
public void setProductName(String productName) {
this.productName = productName;
}
/**
*
* The name of the product that generated the finding.
*
*
* Security Hub populates this attribute automatically for each finding. You cannot update this attribute with
* BatchImportFindings
or BatchUpdateFindings
. The exception to this is a custom
* integration.
*
*
* When you use the Security Hub console or API to filter findings by product name, you use this attribute.
*
*
* @return The name of the product that generated the finding.
*
* Security Hub populates this attribute automatically for each finding. You cannot update this attribute
* with BatchImportFindings
or BatchUpdateFindings
. The exception to this is a
* custom integration.
*
*
* When you use the Security Hub console or API to filter findings by product name, you use this attribute.
*/
public String getProductName() {
return this.productName;
}
/**
*
* The name of the product that generated the finding.
*
*
* Security Hub populates this attribute automatically for each finding. You cannot update this attribute with
* BatchImportFindings
or BatchUpdateFindings
. The exception to this is a custom
* integration.
*
*
* When you use the Security Hub console or API to filter findings by product name, you use this attribute.
*
*
* @param productName
* The name of the product that generated the finding.
*
* Security Hub populates this attribute automatically for each finding. You cannot update this attribute
* with BatchImportFindings
or BatchUpdateFindings
. The exception to this is a
* custom integration.
*
*
* When you use the Security Hub console or API to filter findings by product name, you use this attribute.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public AwsSecurityFinding withProductName(String productName) {
setProductName(productName);
return this;
}
/**
*
* The name of the company for the product that generated the finding.
*
*
* Security Hub populates this attribute automatically for each finding. You cannot update this attribute with
* BatchImportFindings
or BatchUpdateFindings
. The exception to this is a custom
* integration.
*
*
* When you use the Security Hub console or API to filter findings by company name, you use this attribute.
*
*
* @param companyName
* The name of the company for the product that generated the finding.
*
* Security Hub populates this attribute automatically for each finding. You cannot update this attribute
* with BatchImportFindings
or BatchUpdateFindings
. The exception to this is a
* custom integration.
*
*
* When you use the Security Hub console or API to filter findings by company name, you use this attribute.
*/
public void setCompanyName(String companyName) {
this.companyName = companyName;
}
/**
*
* The name of the company for the product that generated the finding.
*
*
* Security Hub populates this attribute automatically for each finding. You cannot update this attribute with
* BatchImportFindings
or BatchUpdateFindings
. The exception to this is a custom
* integration.
*
*
* When you use the Security Hub console or API to filter findings by company name, you use this attribute.
*
*
* @return The name of the company for the product that generated the finding.
*
* Security Hub populates this attribute automatically for each finding. You cannot update this attribute
* with BatchImportFindings
or BatchUpdateFindings
. The exception to this is a
* custom integration.
*
*
* When you use the Security Hub console or API to filter findings by company name, you use this attribute.
*/
public String getCompanyName() {
return this.companyName;
}
/**
*
* The name of the company for the product that generated the finding.
*
*
* Security Hub populates this attribute automatically for each finding. You cannot update this attribute with
* BatchImportFindings
or BatchUpdateFindings
. The exception to this is a custom
* integration.
*
*
* When you use the Security Hub console or API to filter findings by company name, you use this attribute.
*
*
* @param companyName
* The name of the company for the product that generated the finding.
*
* Security Hub populates this attribute automatically for each finding. You cannot update this attribute
* with BatchImportFindings
or BatchUpdateFindings
. The exception to this is a
* custom integration.
*
*
* When you use the Security Hub console or API to filter findings by company name, you use this attribute.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public AwsSecurityFinding withCompanyName(String companyName) {
setCompanyName(companyName);
return this;
}
/**
*
* The Region from which the finding was generated.
*
*
* Security Hub populates this attribute automatically for each finding. You cannot update it using
* BatchImportFindings
or BatchUpdateFindings
.
*
*
* @param region
* The Region from which the finding was generated.
*
* Security Hub populates this attribute automatically for each finding. You cannot update it using
* BatchImportFindings
or BatchUpdateFindings
.
*/
public void setRegion(String region) {
this.region = region;
}
/**
*
* The Region from which the finding was generated.
*
*
* Security Hub populates this attribute automatically for each finding. You cannot update it using
* BatchImportFindings
or BatchUpdateFindings
.
*
*
* @return The Region from which the finding was generated.
*
* Security Hub populates this attribute automatically for each finding. You cannot update it using
* BatchImportFindings
or BatchUpdateFindings
.
*/
public String getRegion() {
return this.region;
}
/**
*
* The Region from which the finding was generated.
*
*
* Security Hub populates this attribute automatically for each finding. You cannot update it using
* BatchImportFindings
or BatchUpdateFindings
.
*
*
* @param region
* The Region from which the finding was generated.
*
* Security Hub populates this attribute automatically for each finding. You cannot update it using
* BatchImportFindings
or BatchUpdateFindings
.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public AwsSecurityFinding withRegion(String region) {
setRegion(region);
return this;
}
/**
*
* The identifier for the solution-specific component (a discrete unit of logic) that generated a finding. In
* various security findings providers' solutions, this generator can be called a rule, a check, a detector, a
* plugin, etc.
*
*
* @param generatorId
* The identifier for the solution-specific component (a discrete unit of logic) that generated a finding. In
* various security findings providers' solutions, this generator can be called a rule, a check, a detector,
* a plugin, etc.
*/
public void setGeneratorId(String generatorId) {
this.generatorId = generatorId;
}
/**
*
* The identifier for the solution-specific component (a discrete unit of logic) that generated a finding. In
* various security findings providers' solutions, this generator can be called a rule, a check, a detector, a
* plugin, etc.
*
*
* @return The identifier for the solution-specific component (a discrete unit of logic) that generated a finding.
* In various security findings providers' solutions, this generator can be called a rule, a check, a
* detector, a plugin, etc.
*/
public String getGeneratorId() {
return this.generatorId;
}
/**
*
* The identifier for the solution-specific component (a discrete unit of logic) that generated a finding. In
* various security findings providers' solutions, this generator can be called a rule, a check, a detector, a
* plugin, etc.
*
*
* @param generatorId
* The identifier for the solution-specific component (a discrete unit of logic) that generated a finding. In
* various security findings providers' solutions, this generator can be called a rule, a check, a detector,
* a plugin, etc.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public AwsSecurityFinding withGeneratorId(String generatorId) {
setGeneratorId(generatorId);
return this;
}
/**
*
* The Amazon Web Services account ID that a finding is generated in.
*
*
* @param awsAccountId
* The Amazon Web Services account ID that a finding is generated in.
*/
public void setAwsAccountId(String awsAccountId) {
this.awsAccountId = awsAccountId;
}
/**
*
* The Amazon Web Services account ID that a finding is generated in.
*
*
* @return The Amazon Web Services account ID that a finding is generated in.
*/
public String getAwsAccountId() {
return this.awsAccountId;
}
/**
*
* The Amazon Web Services account ID that a finding is generated in.
*
*
* @param awsAccountId
* The Amazon Web Services account ID that a finding is generated in.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public AwsSecurityFinding withAwsAccountId(String awsAccountId) {
setAwsAccountId(awsAccountId);
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 AwsSecurityFinding 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 AwsSecurityFinding withTypes(java.util.Collection types) {
setTypes(types);
return this;
}
/**
*
* Indicates when the security findings provider first observed the potential security issue that a finding
* captured.
*
*
* Uses the date-time
format specified in RFC
* 3339 section 5.6, Internet Date/Time Format. The value cannot contain spaces, and date and time should be
* separated by T
. For example, 2020-03-22T13:22:13.933Z
.
*
*
* @param firstObservedAt
* Indicates when the security findings provider first observed the potential security issue that a finding
* captured.
*
* Uses the date-time
format specified in RFC 3339 section 5.6, Internet Date/Time
* Format. The value cannot contain spaces, and date and time should be separated by T
. For
* example, 2020-03-22T13:22:13.933Z
.
*/
public void setFirstObservedAt(String firstObservedAt) {
this.firstObservedAt = firstObservedAt;
}
/**
*
* Indicates when the security findings provider first observed the potential security issue that a finding
* captured.
*
*
* Uses the date-time
format specified in RFC
* 3339 section 5.6, Internet Date/Time Format. The value cannot contain spaces, and date and time should be
* separated by T
. For example, 2020-03-22T13:22:13.933Z
.
*
*
* @return Indicates when the security findings provider first observed the potential security issue that a finding
* captured.
*
* Uses the date-time
format specified in RFC 3339 section 5.6, Internet Date/Time
* Format. The value cannot contain spaces, and date and time should be separated by T
. For
* example, 2020-03-22T13:22:13.933Z
.
*/
public String getFirstObservedAt() {
return this.firstObservedAt;
}
/**
*
* Indicates when the security findings provider first observed the potential security issue that a finding
* captured.
*
*
* Uses the date-time
format specified in RFC
* 3339 section 5.6, Internet Date/Time Format. The value cannot contain spaces, and date and time should be
* separated by T
. For example, 2020-03-22T13:22:13.933Z
.
*
*
* @param firstObservedAt
* Indicates when the security findings provider first observed the potential security issue that a finding
* captured.
*
* Uses the date-time
format specified in RFC 3339 section 5.6, Internet Date/Time
* Format. The value cannot contain spaces, and date and time should be separated by T
. For
* example, 2020-03-22T13:22:13.933Z
.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public AwsSecurityFinding withFirstObservedAt(String firstObservedAt) {
setFirstObservedAt(firstObservedAt);
return this;
}
/**
*
* Indicates when the security findings provider most recently observed the potential security issue that a finding
* captured.
*
*
* Uses the date-time
format specified in RFC
* 3339 section 5.6, Internet Date/Time Format. The value cannot contain spaces, and date and time should be
* separated by T
. For example, 2020-03-22T13:22:13.933Z
.
*
*
* @param lastObservedAt
* Indicates when the security findings provider most recently observed the potential security issue that a
* finding captured.
*
* Uses the date-time
format specified in RFC 3339 section 5.6, Internet Date/Time
* Format. The value cannot contain spaces, and date and time should be separated by T
. For
* example, 2020-03-22T13:22:13.933Z
.
*/
public void setLastObservedAt(String lastObservedAt) {
this.lastObservedAt = lastObservedAt;
}
/**
*
* Indicates when the security findings provider most recently observed the potential security issue that a finding
* captured.
*
*
* Uses the date-time
format specified in RFC
* 3339 section 5.6, Internet Date/Time Format. The value cannot contain spaces, and date and time should be
* separated by T
. For example, 2020-03-22T13:22:13.933Z
.
*
*
* @return Indicates when the security findings provider most recently observed the potential security issue that a
* finding captured.
*
* Uses the date-time
format specified in RFC 3339 section 5.6, Internet Date/Time
* Format. The value cannot contain spaces, and date and time should be separated by T
. For
* example, 2020-03-22T13:22:13.933Z
.
*/
public String getLastObservedAt() {
return this.lastObservedAt;
}
/**
*
* Indicates when the security findings provider most recently observed the potential security issue that a finding
* captured.
*
*
* Uses the date-time
format specified in RFC
* 3339 section 5.6, Internet Date/Time Format. The value cannot contain spaces, and date and time should be
* separated by T
. For example, 2020-03-22T13:22:13.933Z
.
*
*
* @param lastObservedAt
* Indicates when the security findings provider most recently observed the potential security issue that a
* finding captured.
*
* Uses the date-time
format specified in RFC 3339 section 5.6, Internet Date/Time
* Format. The value cannot contain spaces, and date and time should be separated by T
. For
* example, 2020-03-22T13:22:13.933Z
.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public AwsSecurityFinding withLastObservedAt(String lastObservedAt) {
setLastObservedAt(lastObservedAt);
return this;
}
/**
*
* Indicates when the security findings provider created the potential security issue that a finding captured.
*
*
* Uses the date-time
format specified in RFC
* 3339 section 5.6, Internet Date/Time Format. The value cannot contain spaces, and date and time should be
* separated by T
. For example, 2020-03-22T13:22:13.933Z
.
*
*
* @param createdAt
* Indicates when the security findings provider created the potential security issue that a finding
* captured.
*
* Uses the date-time
format specified in RFC 3339 section 5.6, Internet Date/Time
* Format. The value cannot contain spaces, and date and time should be separated by T
. For
* example, 2020-03-22T13:22:13.933Z
.
*/
public void setCreatedAt(String createdAt) {
this.createdAt = createdAt;
}
/**
*
* Indicates when the security findings provider created the potential security issue that a finding captured.
*
*
* Uses the date-time
format specified in RFC
* 3339 section 5.6, Internet Date/Time Format. The value cannot contain spaces, and date and time should be
* separated by T
. For example, 2020-03-22T13:22:13.933Z
.
*
*
* @return Indicates when the security findings provider created the potential security issue that a finding
* captured.
*
* Uses the date-time
format specified in RFC 3339 section 5.6, Internet Date/Time
* Format. The value cannot contain spaces, and date and time should be separated by T
. For
* example, 2020-03-22T13:22:13.933Z
.
*/
public String getCreatedAt() {
return this.createdAt;
}
/**
*
* Indicates when the security findings provider created the potential security issue that a finding captured.
*
*
* Uses the date-time
format specified in RFC
* 3339 section 5.6, Internet Date/Time Format. The value cannot contain spaces, and date and time should be
* separated by T
. For example, 2020-03-22T13:22:13.933Z
.
*
*
* @param createdAt
* Indicates when the security findings provider created the potential security issue that a finding
* captured.
*
* Uses the date-time
format specified in RFC 3339 section 5.6, Internet Date/Time
* Format. The value cannot contain spaces, and date and time should be separated by T
. For
* example, 2020-03-22T13:22:13.933Z
.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public AwsSecurityFinding withCreatedAt(String createdAt) {
setCreatedAt(createdAt);
return this;
}
/**
*
* Indicates when the security findings provider last updated the finding record.
*
*
* Uses the date-time
format specified in RFC
* 3339 section 5.6, Internet Date/Time Format. The value cannot contain spaces, and date and time should be
* separated by T
. For example, 2020-03-22T13:22:13.933Z
.
*
*
* @param updatedAt
* Indicates when the security findings provider last updated the finding record.
*
* Uses the date-time
format specified in RFC 3339 section 5.6, Internet Date/Time
* Format. The value cannot contain spaces, and date and time should be separated by T
. For
* example, 2020-03-22T13:22:13.933Z
.
*/
public void setUpdatedAt(String updatedAt) {
this.updatedAt = updatedAt;
}
/**
*
* Indicates when the security findings provider last updated the finding record.
*
*
* Uses the date-time
format specified in RFC
* 3339 section 5.6, Internet Date/Time Format. The value cannot contain spaces, and date and time should be
* separated by T
. For example, 2020-03-22T13:22:13.933Z
.
*
*
* @return Indicates when the security findings provider last updated the finding record.
*
* Uses the date-time
format specified in RFC 3339 section 5.6, Internet Date/Time
* Format. The value cannot contain spaces, and date and time should be separated by T
. For
* example, 2020-03-22T13:22:13.933Z
.
*/
public String getUpdatedAt() {
return this.updatedAt;
}
/**
*
* Indicates when the security findings provider last updated the finding record.
*
*
* Uses the date-time
format specified in RFC
* 3339 section 5.6, Internet Date/Time Format. The value cannot contain spaces, and date and time should be
* separated by T
. For example, 2020-03-22T13:22:13.933Z
.
*
*
* @param updatedAt
* Indicates when the security findings provider last updated the finding record.
*
* Uses the date-time
format specified in RFC 3339 section 5.6, Internet Date/Time
* Format. The value cannot contain spaces, and date and time should be separated by T
. For
* example, 2020-03-22T13:22:13.933Z
.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public AwsSecurityFinding withUpdatedAt(String updatedAt) {
setUpdatedAt(updatedAt);
return this;
}
/**
*
* A finding's severity.
*
*
* @param severity
* A finding's severity.
*/
public void setSeverity(Severity severity) {
this.severity = severity;
}
/**
*
* A finding's severity.
*
*
* @return A finding's severity.
*/
public Severity getSeverity() {
return this.severity;
}
/**
*
* A finding's severity.
*
*
* @param severity
* A finding's severity.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public AwsSecurityFinding withSeverity(Severity severity) {
setSeverity(severity);
return this;
}
/**
*
* 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 AwsSecurityFinding 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 AwsSecurityFinding withCriticality(Integer criticality) {
setCriticality(criticality);
return this;
}
/**
*
* A finding's title.
*
*
*
* In this release, Title
is a required property.
*
*
*
* @param title
* A finding's title.
*
* In this release, Title
is a required property.
*
*/
public void setTitle(String title) {
this.title = title;
}
/**
*
* A finding's title.
*
*
*
* In this release, Title
is a required property.
*
*
*
* @return A finding's title.
*
* In this release, Title
is a required property.
*
*/
public String getTitle() {
return this.title;
}
/**
*
* A finding's title.
*
*
*
* In this release, Title
is a required property.
*
*
*
* @param title
* A finding's title.
*
* In this release, Title
is a required property.
*
* @return Returns a reference to this object so that method calls can be chained together.
*/
public AwsSecurityFinding withTitle(String title) {
setTitle(title);
return this;
}
/**
*
* A finding's description.
*
*
*
* In this release, Description
is a required property.
*
*
*
* @param description
* A finding's description.
*
* In this release, Description
is a required property.
*
*/
public void setDescription(String description) {
this.description = description;
}
/**
*
* A finding's description.
*
*
*
* In this release, Description
is a required property.
*
*
*
* @return A finding's description.
*
* In this release, Description
is a required property.
*
*/
public String getDescription() {
return this.description;
}
/**
*
* A finding's description.
*
*
*
* In this release, Description
is a required property.
*
*
*
* @param description
* A finding's description.
*
* In this release, Description
is a required property.
*
* @return Returns a reference to this object so that method calls can be chained together.
*/
public AwsSecurityFinding withDescription(String description) {
setDescription(description);
return this;
}
/**
*
* A data type that describes the remediation options for a finding.
*
*
* @param remediation
* A data type that describes the remediation options for a finding.
*/
public void setRemediation(Remediation remediation) {
this.remediation = remediation;
}
/**
*
* A data type that describes the remediation options for a finding.
*
*
* @return A data type that describes the remediation options for a finding.
*/
public Remediation getRemediation() {
return this.remediation;
}
/**
*
* A data type that describes the remediation options for a finding.
*
*
* @param remediation
* A data type that describes the remediation options for a finding.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public AwsSecurityFinding withRemediation(Remediation remediation) {
setRemediation(remediation);
return this;
}
/**
*
* A URL that links to a page about the current finding in the security findings provider's solution.
*
*
* @param sourceUrl
* A URL that links to a page about the current finding in the security findings provider's solution.
*/
public void setSourceUrl(String sourceUrl) {
this.sourceUrl = sourceUrl;
}
/**
*
* A URL that links to a page about the current finding in the security findings provider's solution.
*
*
* @return A URL that links to a page about the current finding in the security findings provider's solution.
*/
public String getSourceUrl() {
return this.sourceUrl;
}
/**
*
* A URL that links to a page about the current finding in the security findings provider's solution.
*
*
* @param sourceUrl
* A URL that links to a page about the current finding in the security findings provider's solution.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public AwsSecurityFinding withSourceUrl(String sourceUrl) {
setSourceUrl(sourceUrl);
return this;
}
/**
*
* A data type where security findings providers can include additional solution-specific details that aren't part
* of the defined AwsSecurityFinding
format.
*
*
* Can contain up to 50 key-value pairs. For each key-value pair, the key can contain up to 128 characters, and the
* value can contain up to 2048 characters.
*
*
* @return A data type where security findings providers can include additional solution-specific details that
* aren't part of the defined AwsSecurityFinding
format.
*
* Can contain up to 50 key-value pairs. For each key-value pair, the key can contain up to 128 characters,
* and the value can contain up to 2048 characters.
*/
public java.util.Map getProductFields() {
return productFields;
}
/**
*
* A data type where security findings providers can include additional solution-specific details that aren't part
* of the defined AwsSecurityFinding
format.
*
*
* Can contain up to 50 key-value pairs. For each key-value pair, the key can contain up to 128 characters, and the
* value can contain up to 2048 characters.
*
*
* @param productFields
* A data type where security findings providers can include additional solution-specific details that aren't
* part of the defined AwsSecurityFinding
format.
*
* Can contain up to 50 key-value pairs. For each key-value pair, the key can contain up to 128 characters,
* and the value can contain up to 2048 characters.
*/
public void setProductFields(java.util.Map productFields) {
this.productFields = productFields;
}
/**
*
* A data type where security findings providers can include additional solution-specific details that aren't part
* of the defined AwsSecurityFinding
format.
*
*
* Can contain up to 50 key-value pairs. For each key-value pair, the key can contain up to 128 characters, and the
* value can contain up to 2048 characters.
*
*
* @param productFields
* A data type where security findings providers can include additional solution-specific details that aren't
* part of the defined AwsSecurityFinding
format.
*
* Can contain up to 50 key-value pairs. For each key-value pair, the key can contain up to 128 characters,
* and the value can contain up to 2048 characters.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public AwsSecurityFinding withProductFields(java.util.Map productFields) {
setProductFields(productFields);
return this;
}
/**
* Add a single ProductFields entry
*
* @see AwsSecurityFinding#withProductFields
* @returns a reference to this object so that method calls can be chained together.
*/
public AwsSecurityFinding addProductFieldsEntry(String key, String value) {
if (null == this.productFields) {
this.productFields = new java.util.HashMap();
}
if (this.productFields.containsKey(key))
throw new IllegalArgumentException("Duplicated keys (" + key.toString() + ") are provided.");
this.productFields.put(key, value);
return this;
}
/**
* Removes all the entries added into ProductFields.
*
* @return Returns a reference to this object so that method calls can be chained together.
*/
public AwsSecurityFinding clearProductFieldsEntries() {
this.productFields = null;
return this;
}
/**
*
* A list of name/value string pairs associated with the finding. These are custom, user-defined fields added to a
* finding.
*
*
* @return A list of name/value string pairs associated with the finding. These are custom, user-defined fields
* added to a finding.
*/
public java.util.Map getUserDefinedFields() {
return userDefinedFields;
}
/**
*
* A list of name/value string pairs associated with the finding. These are custom, user-defined fields added to a
* finding.
*
*
* @param userDefinedFields
* A list of name/value string pairs associated with the finding. These are custom, user-defined fields added
* to a finding.
*/
public void setUserDefinedFields(java.util.Map userDefinedFields) {
this.userDefinedFields = userDefinedFields;
}
/**
*
* A list of name/value string pairs associated with the finding. These are custom, user-defined fields added to a
* finding.
*
*
* @param userDefinedFields
* A list of name/value string pairs associated with the finding. These are custom, user-defined fields added
* to a finding.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public AwsSecurityFinding withUserDefinedFields(java.util.Map userDefinedFields) {
setUserDefinedFields(userDefinedFields);
return this;
}
/**
* Add a single UserDefinedFields entry
*
* @see AwsSecurityFinding#withUserDefinedFields
* @returns a reference to this object so that method calls can be chained together.
*/
public AwsSecurityFinding addUserDefinedFieldsEntry(String key, String value) {
if (null == this.userDefinedFields) {
this.userDefinedFields = new java.util.HashMap();
}
if (this.userDefinedFields.containsKey(key))
throw new IllegalArgumentException("Duplicated keys (" + key.toString() + ") are provided.");
this.userDefinedFields.put(key, value);
return this;
}
/**
* Removes all the entries added into UserDefinedFields.
*
* @return Returns a reference to this object so that method calls can be chained together.
*/
public AwsSecurityFinding clearUserDefinedFieldsEntries() {
this.userDefinedFields = null;
return this;
}
/**
*
* A list of malware related to a finding.
*
*
* @return A list of malware related to a finding.
*/
public java.util.List getMalware() {
return malware;
}
/**
*
* A list of malware related to a finding.
*
*
* @param malware
* A list of malware related to a finding.
*/
public void setMalware(java.util.Collection malware) {
if (malware == null) {
this.malware = null;
return;
}
this.malware = new java.util.ArrayList(malware);
}
/**
*
* A list of malware related to a finding.
*
*
* NOTE: This method appends the values to the existing list (if any). Use
* {@link #setMalware(java.util.Collection)} or {@link #withMalware(java.util.Collection)} if you want to override
* the existing values.
*
*
* @param malware
* A list of malware related to a finding.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public AwsSecurityFinding withMalware(Malware... malware) {
if (this.malware == null) {
setMalware(new java.util.ArrayList(malware.length));
}
for (Malware ele : malware) {
this.malware.add(ele);
}
return this;
}
/**
*
* A list of malware related to a finding.
*
*
* @param malware
* A list of malware related to a finding.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public AwsSecurityFinding withMalware(java.util.Collection malware) {
setMalware(malware);
return this;
}
/**
*
* The details of network-related information about a finding.
*
*
* @param network
* The details of network-related information about a finding.
*/
public void setNetwork(Network network) {
this.network = network;
}
/**
*
* The details of network-related information about a finding.
*
*
* @return The details of network-related information about a finding.
*/
public Network getNetwork() {
return this.network;
}
/**
*
* The details of network-related information about a finding.
*
*
* @param network
* The details of network-related information about a finding.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public AwsSecurityFinding withNetwork(Network network) {
setNetwork(network);
return this;
}
/**
*
* Provides information about a network path that is relevant to a finding. Each entry under
* NetworkPath
represents a component of that path.
*
*
* @return Provides information about a network path that is relevant to a finding. Each entry under
* NetworkPath
represents a component of that path.
*/
public java.util.List getNetworkPath() {
return networkPath;
}
/**
*
* Provides information about a network path that is relevant to a finding. Each entry under
* NetworkPath
represents a component of that path.
*
*
* @param networkPath
* Provides information about a network path that is relevant to a finding. Each entry under
* NetworkPath
represents a component of that path.
*/
public void setNetworkPath(java.util.Collection networkPath) {
if (networkPath == null) {
this.networkPath = null;
return;
}
this.networkPath = new java.util.ArrayList(networkPath);
}
/**
*
* Provides information about a network path that is relevant to a finding. Each entry under
* NetworkPath
represents a component of that path.
*
*
* NOTE: This method appends the values to the existing list (if any). Use
* {@link #setNetworkPath(java.util.Collection)} or {@link #withNetworkPath(java.util.Collection)} if you want to
* override the existing values.
*
*
* @param networkPath
* Provides information about a network path that is relevant to a finding. Each entry under
* NetworkPath
represents a component of that path.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public AwsSecurityFinding withNetworkPath(NetworkPathComponent... networkPath) {
if (this.networkPath == null) {
setNetworkPath(new java.util.ArrayList(networkPath.length));
}
for (NetworkPathComponent ele : networkPath) {
this.networkPath.add(ele);
}
return this;
}
/**
*
* Provides information about a network path that is relevant to a finding. Each entry under
* NetworkPath
represents a component of that path.
*
*
* @param networkPath
* Provides information about a network path that is relevant to a finding. Each entry under
* NetworkPath
represents a component of that path.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public AwsSecurityFinding withNetworkPath(java.util.Collection networkPath) {
setNetworkPath(networkPath);
return this;
}
/**
*
* The details of process-related information about a finding.
*
*
* @param process
* The details of process-related information about a finding.
*/
public void setProcess(ProcessDetails process) {
this.process = process;
}
/**
*
* The details of process-related information about a finding.
*
*
* @return The details of process-related information about a finding.
*/
public ProcessDetails getProcess() {
return this.process;
}
/**
*
* The details of process-related information about a finding.
*
*
* @param process
* The details of process-related information about a finding.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public AwsSecurityFinding withProcess(ProcessDetails process) {
setProcess(process);
return this;
}
/**
*
* Details about the threat detected in a security finding and the file paths that were affected by the threat.
*
*
* @return Details about the threat detected in a security finding and the file paths that were affected by the
* threat.
*/
public java.util.List getThreats() {
return threats;
}
/**
*
* Details about the threat detected in a security finding and the file paths that were affected by the threat.
*
*
* @param threats
* Details about the threat detected in a security finding and the file paths that were affected by the
* threat.
*/
public void setThreats(java.util.Collection threats) {
if (threats == null) {
this.threats = null;
return;
}
this.threats = new java.util.ArrayList(threats);
}
/**
*
* Details about the threat detected in a security finding and the file paths that were affected by the threat.
*
*
* NOTE: This method appends the values to the existing list (if any). Use
* {@link #setThreats(java.util.Collection)} or {@link #withThreats(java.util.Collection)} if you want to override
* the existing values.
*
*
* @param threats
* Details about the threat detected in a security finding and the file paths that were affected by the
* threat.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public AwsSecurityFinding withThreats(Threat... threats) {
if (this.threats == null) {
setThreats(new java.util.ArrayList(threats.length));
}
for (Threat ele : threats) {
this.threats.add(ele);
}
return this;
}
/**
*
* Details about the threat detected in a security finding and the file paths that were affected by the threat.
*
*
* @param threats
* Details about the threat detected in a security finding and the file paths that were affected by the
* threat.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public AwsSecurityFinding withThreats(java.util.Collection threats) {
setThreats(threats);
return this;
}
/**
*
* Threat intelligence details related to a finding.
*
*
* @return Threat intelligence details related to a finding.
*/
public java.util.List getThreatIntelIndicators() {
return threatIntelIndicators;
}
/**
*
* Threat intelligence details related to a finding.
*
*
* @param threatIntelIndicators
* Threat intelligence details related to a finding.
*/
public void setThreatIntelIndicators(java.util.Collection threatIntelIndicators) {
if (threatIntelIndicators == null) {
this.threatIntelIndicators = null;
return;
}
this.threatIntelIndicators = new java.util.ArrayList(threatIntelIndicators);
}
/**
*
* Threat intelligence details related to a finding.
*
*
* NOTE: This method appends the values to the existing list (if any). Use
* {@link #setThreatIntelIndicators(java.util.Collection)} or
* {@link #withThreatIntelIndicators(java.util.Collection)} if you want to override the existing values.
*
*
* @param threatIntelIndicators
* Threat intelligence details related to a finding.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public AwsSecurityFinding withThreatIntelIndicators(ThreatIntelIndicator... threatIntelIndicators) {
if (this.threatIntelIndicators == null) {
setThreatIntelIndicators(new java.util.ArrayList(threatIntelIndicators.length));
}
for (ThreatIntelIndicator ele : threatIntelIndicators) {
this.threatIntelIndicators.add(ele);
}
return this;
}
/**
*
* Threat intelligence details related to a finding.
*
*
* @param threatIntelIndicators
* Threat intelligence details related to a finding.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public AwsSecurityFinding withThreatIntelIndicators(java.util.Collection threatIntelIndicators) {
setThreatIntelIndicators(threatIntelIndicators);
return this;
}
/**
*
* A set of resource data types that describe the resources that the finding refers to.
*
*
* @return A set of resource data types that describe the resources that the finding refers to.
*/
public java.util.List getResources() {
return resources;
}
/**
*
* A set of resource data types that describe the resources that the finding refers to.
*
*
* @param resources
* A set of resource data types that describe the resources that the finding refers to.
*/
public void setResources(java.util.Collection resources) {
if (resources == null) {
this.resources = null;
return;
}
this.resources = new java.util.ArrayList(resources);
}
/**
*
* A set of resource data types that describe the resources that the finding refers to.
*
*
* NOTE: This method appends the values to the existing list (if any). Use
* {@link #setResources(java.util.Collection)} or {@link #withResources(java.util.Collection)} if you want to
* override the existing values.
*
*
* @param resources
* A set of resource data types that describe the resources that the finding refers to.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public AwsSecurityFinding withResources(Resource... resources) {
if (this.resources == null) {
setResources(new java.util.ArrayList(resources.length));
}
for (Resource ele : resources) {
this.resources.add(ele);
}
return this;
}
/**
*
* A set of resource data types that describe the resources that the finding refers to.
*
*
* @param resources
* A set of resource data types that describe the resources that the finding refers to.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public AwsSecurityFinding withResources(java.util.Collection resources) {
setResources(resources);
return this;
}
/**
*
* This data type is exclusive to findings that are generated as the result of a check run against a specific rule
* in a supported security standard, such as CIS Amazon Web Services Foundations. Contains security standard-related
* finding details.
*
*
* @param compliance
* This data type is exclusive to findings that are generated as the result of a check run against a specific
* rule in a supported security standard, such as CIS Amazon Web Services Foundations. Contains security
* standard-related finding details.
*/
public void setCompliance(Compliance compliance) {
this.compliance = compliance;
}
/**
*
* This data type is exclusive to findings that are generated as the result of a check run against a specific rule
* in a supported security standard, such as CIS Amazon Web Services Foundations. Contains security standard-related
* finding details.
*
*
* @return This data type is exclusive to findings that are generated as the result of a check run against a
* specific rule in a supported security standard, such as CIS Amazon Web Services Foundations. Contains
* security standard-related finding details.
*/
public Compliance getCompliance() {
return this.compliance;
}
/**
*
* This data type is exclusive to findings that are generated as the result of a check run against a specific rule
* in a supported security standard, such as CIS Amazon Web Services Foundations. Contains security standard-related
* finding details.
*
*
* @param compliance
* This data type is exclusive to findings that are generated as the result of a check run against a specific
* rule in a supported security standard, such as CIS Amazon Web Services Foundations. Contains security
* standard-related finding details.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public AwsSecurityFinding withCompliance(Compliance compliance) {
setCompliance(compliance);
return this;
}
/**
*
* Indicates the veracity of a finding.
*
*
* @param verificationState
* Indicates the veracity of a finding.
* @see VerificationState
*/
public void setVerificationState(String verificationState) {
this.verificationState = verificationState;
}
/**
*
* Indicates the veracity of a finding.
*
*
* @return Indicates the veracity of a finding.
* @see VerificationState
*/
public String getVerificationState() {
return this.verificationState;
}
/**
*
* Indicates the veracity of a finding.
*
*
* @param verificationState
* Indicates the veracity of a finding.
* @return Returns a reference to this object so that method calls can be chained together.
* @see VerificationState
*/
public AwsSecurityFinding withVerificationState(String verificationState) {
setVerificationState(verificationState);
return this;
}
/**
*
* Indicates the veracity of a finding.
*
*
* @param verificationState
* Indicates the veracity of a finding.
* @return Returns a reference to this object so that method calls can be chained together.
* @see VerificationState
*/
public AwsSecurityFinding withVerificationState(VerificationState verificationState) {
this.verificationState = verificationState.toString();
return this;
}
/**
*
* The workflow state of a finding.
*
*
* @param workflowState
* The workflow state of a finding.
* @see WorkflowState
*/
@Deprecated
public void setWorkflowState(String workflowState) {
this.workflowState = workflowState;
}
/**
*
* The workflow state of a finding.
*
*
* @return The workflow state of a finding.
* @see WorkflowState
*/
@Deprecated
public String getWorkflowState() {
return this.workflowState;
}
/**
*
* The workflow state of a finding.
*
*
* @param workflowState
* The workflow state of a finding.
* @return Returns a reference to this object so that method calls can be chained together.
* @see WorkflowState
*/
@Deprecated
public AwsSecurityFinding withWorkflowState(String workflowState) {
setWorkflowState(workflowState);
return this;
}
/**
*
* The workflow state of a finding.
*
*
* @param workflowState
* The workflow state of a finding.
* @return Returns a reference to this object so that method calls can be chained together.
* @see WorkflowState
*/
@Deprecated
public AwsSecurityFinding withWorkflowState(WorkflowState workflowState) {
this.workflowState = workflowState.toString();
return this;
}
/**
*
* Provides information about the status of the investigation into a finding.
*
*
* @param workflow
* Provides information about the status of the investigation into a finding.
*/
public void setWorkflow(Workflow workflow) {
this.workflow = workflow;
}
/**
*
* Provides information about the status of the investigation into a finding.
*
*
* @return Provides information about the status of the investigation into a finding.
*/
public Workflow getWorkflow() {
return this.workflow;
}
/**
*
* Provides information about the status of the investigation into a finding.
*
*
* @param workflow
* Provides information about the status of the investigation into a finding.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public AwsSecurityFinding withWorkflow(Workflow workflow) {
setWorkflow(workflow);
return this;
}
/**
*
* The record state of a finding.
*
*
* @param recordState
* The record state of a finding.
* @see RecordState
*/
public void setRecordState(String recordState) {
this.recordState = recordState;
}
/**
*
* The record state of a finding.
*
*
* @return The record state of a finding.
* @see RecordState
*/
public String getRecordState() {
return this.recordState;
}
/**
*
* The record state of a finding.
*
*
* @param recordState
* The record state of a finding.
* @return Returns a reference to this object so that method calls can be chained together.
* @see RecordState
*/
public AwsSecurityFinding withRecordState(String recordState) {
setRecordState(recordState);
return this;
}
/**
*
* The record state of a finding.
*
*
* @param recordState
* The record state of a finding.
* @return Returns a reference to this object so that method calls can be chained together.
* @see RecordState
*/
public AwsSecurityFinding withRecordState(RecordState recordState) {
this.recordState = recordState.toString();
return this;
}
/**
*
* A list of related findings.
*
*
* @return A list of related findings.
*/
public java.util.List getRelatedFindings() {
return relatedFindings;
}
/**
*
* A list of related findings.
*
*
* @param relatedFindings
* A list of related findings.
*/
public void setRelatedFindings(java.util.Collection relatedFindings) {
if (relatedFindings == null) {
this.relatedFindings = null;
return;
}
this.relatedFindings = new java.util.ArrayList(relatedFindings);
}
/**
*
* A list of related findings.
*
*
* 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 related findings.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public AwsSecurityFinding 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 related findings.
*
*
* @param relatedFindings
* A list of related findings.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public AwsSecurityFinding withRelatedFindings(java.util.Collection relatedFindings) {
setRelatedFindings(relatedFindings);
return this;
}
/**
*
* A user-defined note added to a finding.
*
*
* @param note
* A user-defined note added to a finding.
*/
public void setNote(Note note) {
this.note = note;
}
/**
*
* A user-defined note added to a finding.
*
*
* @return A user-defined note added to a finding.
*/
public Note getNote() {
return this.note;
}
/**
*
* A user-defined note added to a finding.
*
*
* @param note
* A user-defined note added to a finding.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public AwsSecurityFinding withNote(Note note) {
setNote(note);
return this;
}
/**
*
* Provides a list of vulnerabilities associated with the findings.
*
*
* @return Provides a list of vulnerabilities associated with the findings.
*/
public java.util.List getVulnerabilities() {
return vulnerabilities;
}
/**
*
* Provides a list of vulnerabilities associated with the findings.
*
*
* @param vulnerabilities
* Provides a list of vulnerabilities associated with the findings.
*/
public void setVulnerabilities(java.util.Collection vulnerabilities) {
if (vulnerabilities == null) {
this.vulnerabilities = null;
return;
}
this.vulnerabilities = new java.util.ArrayList(vulnerabilities);
}
/**
*
* Provides a list of vulnerabilities associated with the findings.
*
*
* NOTE: This method appends the values to the existing list (if any). Use
* {@link #setVulnerabilities(java.util.Collection)} or {@link #withVulnerabilities(java.util.Collection)} if you
* want to override the existing values.
*
*
* @param vulnerabilities
* Provides a list of vulnerabilities associated with the findings.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public AwsSecurityFinding withVulnerabilities(Vulnerability... vulnerabilities) {
if (this.vulnerabilities == null) {
setVulnerabilities(new java.util.ArrayList(vulnerabilities.length));
}
for (Vulnerability ele : vulnerabilities) {
this.vulnerabilities.add(ele);
}
return this;
}
/**
*
* Provides a list of vulnerabilities associated with the findings.
*
*
* @param vulnerabilities
* Provides a list of vulnerabilities associated with the findings.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public AwsSecurityFinding withVulnerabilities(java.util.Collection vulnerabilities) {
setVulnerabilities(vulnerabilities);
return this;
}
/**
*
* Provides an overview of the patch compliance status for an instance against a selected compliance standard.
*
*
* @param patchSummary
* Provides an overview of the patch compliance status for an instance against a selected compliance
* standard.
*/
public void setPatchSummary(PatchSummary patchSummary) {
this.patchSummary = patchSummary;
}
/**
*
* Provides an overview of the patch compliance status for an instance against a selected compliance standard.
*
*
* @return Provides an overview of the patch compliance status for an instance against a selected compliance
* standard.
*/
public PatchSummary getPatchSummary() {
return this.patchSummary;
}
/**
*
* Provides an overview of the patch compliance status for an instance against a selected compliance standard.
*
*
* @param patchSummary
* Provides an overview of the patch compliance status for an instance against a selected compliance
* standard.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public AwsSecurityFinding withPatchSummary(PatchSummary patchSummary) {
setPatchSummary(patchSummary);
return this;
}
/**
*
* Provides details about an action that affects or that was taken on a resource.
*
*
* @param action
* Provides details about an action that affects or that was taken on a resource.
*/
public void setAction(Action action) {
this.action = action;
}
/**
*
* Provides details about an action that affects or that was taken on a resource.
*
*
* @return Provides details about an action that affects or that was taken on a resource.
*/
public Action getAction() {
return this.action;
}
/**
*
* Provides details about an action that affects or that was taken on a resource.
*
*
* @param action
* Provides details about an action that affects or that was taken on a resource.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public AwsSecurityFinding withAction(Action action) {
setAction(action);
return this;
}
/**
*
* In a BatchImportFindings
request, finding providers use FindingProviderFields
to
* provide and update their own values for confidence, criticality, related findings, severity, and types.
*
*
* @param findingProviderFields
* In a BatchImportFindings
request, finding providers use FindingProviderFields
to
* provide and update their own values for confidence, criticality, related findings, severity, and types.
*/
public void setFindingProviderFields(FindingProviderFields findingProviderFields) {
this.findingProviderFields = findingProviderFields;
}
/**
*
* In a BatchImportFindings
request, finding providers use FindingProviderFields
to
* provide and update their own values for confidence, criticality, related findings, severity, and types.
*
*
* @return In a BatchImportFindings
request, finding providers use FindingProviderFields
* to provide and update their own values for confidence, criticality, related findings, severity, and
* types.
*/
public FindingProviderFields getFindingProviderFields() {
return this.findingProviderFields;
}
/**
*
* In a BatchImportFindings
request, finding providers use FindingProviderFields
to
* provide and update their own values for confidence, criticality, related findings, severity, and types.
*
*
* @param findingProviderFields
* In a BatchImportFindings
request, finding providers use FindingProviderFields
to
* provide and update their own values for confidence, criticality, related findings, severity, and types.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public AwsSecurityFinding withFindingProviderFields(FindingProviderFields findingProviderFields) {
setFindingProviderFields(findingProviderFields);
return this;
}
/**
*
* Indicates whether the finding is a sample finding.
*
*
* @param sample
* Indicates whether the finding is a sample finding.
*/
public void setSample(Boolean sample) {
this.sample = sample;
}
/**
*
* Indicates whether the finding is a sample finding.
*
*
* @return Indicates whether the finding is a sample finding.
*/
public Boolean getSample() {
return this.sample;
}
/**
*
* Indicates whether the finding is a sample finding.
*
*
* @param sample
* Indicates whether the finding is a sample finding.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public AwsSecurityFinding withSample(Boolean sample) {
setSample(sample);
return this;
}
/**
*
* Indicates whether the finding is a sample finding.
*
*
* @return Indicates whether the finding is a sample finding.
*/
public Boolean isSample() {
return this.sample;
}
/**
*
* Provides metadata for the Amazon CodeGuru detector associated with a finding. This field pertains to findings
* that relate to Lambda functions. Amazon Inspector identifies policy violations and vulnerabilities in Lambda
* function code based on internal detectors developed in collaboration with Amazon CodeGuru. Security Hub receives
* those findings.
*
*
* @param generatorDetails
* Provides metadata for the Amazon CodeGuru detector associated with a finding. This field pertains to
* findings that relate to Lambda functions. Amazon Inspector identifies policy violations and
* vulnerabilities in Lambda function code based on internal detectors developed in collaboration with Amazon
* CodeGuru. Security Hub receives those findings.
*/
public void setGeneratorDetails(GeneratorDetails generatorDetails) {
this.generatorDetails = generatorDetails;
}
/**
*
* Provides metadata for the Amazon CodeGuru detector associated with a finding. This field pertains to findings
* that relate to Lambda functions. Amazon Inspector identifies policy violations and vulnerabilities in Lambda
* function code based on internal detectors developed in collaboration with Amazon CodeGuru. Security Hub receives
* those findings.
*
*
* @return Provides metadata for the Amazon CodeGuru detector associated with a finding. This field pertains to
* findings that relate to Lambda functions. Amazon Inspector identifies policy violations and
* vulnerabilities in Lambda function code based on internal detectors developed in collaboration with
* Amazon CodeGuru. Security Hub receives those findings.
*/
public GeneratorDetails getGeneratorDetails() {
return this.generatorDetails;
}
/**
*
* Provides metadata for the Amazon CodeGuru detector associated with a finding. This field pertains to findings
* that relate to Lambda functions. Amazon Inspector identifies policy violations and vulnerabilities in Lambda
* function code based on internal detectors developed in collaboration with Amazon CodeGuru. Security Hub receives
* those findings.
*
*
* @param generatorDetails
* Provides metadata for the Amazon CodeGuru detector associated with a finding. This field pertains to
* findings that relate to Lambda functions. Amazon Inspector identifies policy violations and
* vulnerabilities in Lambda function code based on internal detectors developed in collaboration with Amazon
* CodeGuru. Security Hub receives those findings.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public AwsSecurityFinding withGeneratorDetails(GeneratorDetails generatorDetails) {
setGeneratorDetails(generatorDetails);
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 (getSchemaVersion() != null)
sb.append("SchemaVersion: ").append(getSchemaVersion()).append(",");
if (getId() != null)
sb.append("Id: ").append(getId()).append(",");
if (getProductArn() != null)
sb.append("ProductArn: ").append(getProductArn()).append(",");
if (getProductName() != null)
sb.append("ProductName: ").append(getProductName()).append(",");
if (getCompanyName() != null)
sb.append("CompanyName: ").append(getCompanyName()).append(",");
if (getRegion() != null)
sb.append("Region: ").append(getRegion()).append(",");
if (getGeneratorId() != null)
sb.append("GeneratorId: ").append(getGeneratorId()).append(",");
if (getAwsAccountId() != null)
sb.append("AwsAccountId: ").append(getAwsAccountId()).append(",");
if (getTypes() != null)
sb.append("Types: ").append(getTypes()).append(",");
if (getFirstObservedAt() != null)
sb.append("FirstObservedAt: ").append(getFirstObservedAt()).append(",");
if (getLastObservedAt() != null)
sb.append("LastObservedAt: ").append(getLastObservedAt()).append(",");
if (getCreatedAt() != null)
sb.append("CreatedAt: ").append(getCreatedAt()).append(",");
if (getUpdatedAt() != null)
sb.append("UpdatedAt: ").append(getUpdatedAt()).append(",");
if (getSeverity() != null)
sb.append("Severity: ").append(getSeverity()).append(",");
if (getConfidence() != null)
sb.append("Confidence: ").append(getConfidence()).append(",");
if (getCriticality() != null)
sb.append("Criticality: ").append(getCriticality()).append(",");
if (getTitle() != null)
sb.append("Title: ").append(getTitle()).append(",");
if (getDescription() != null)
sb.append("Description: ").append(getDescription()).append(",");
if (getRemediation() != null)
sb.append("Remediation: ").append(getRemediation()).append(",");
if (getSourceUrl() != null)
sb.append("SourceUrl: ").append(getSourceUrl()).append(",");
if (getProductFields() != null)
sb.append("ProductFields: ").append(getProductFields()).append(",");
if (getUserDefinedFields() != null)
sb.append("UserDefinedFields: ").append(getUserDefinedFields()).append(",");
if (getMalware() != null)
sb.append("Malware: ").append(getMalware()).append(",");
if (getNetwork() != null)
sb.append("Network: ").append(getNetwork()).append(",");
if (getNetworkPath() != null)
sb.append("NetworkPath: ").append(getNetworkPath()).append(",");
if (getProcess() != null)
sb.append("Process: ").append(getProcess()).append(",");
if (getThreats() != null)
sb.append("Threats: ").append(getThreats()).append(",");
if (getThreatIntelIndicators() != null)
sb.append("ThreatIntelIndicators: ").append(getThreatIntelIndicators()).append(",");
if (getResources() != null)
sb.append("Resources: ").append(getResources()).append(",");
if (getCompliance() != null)
sb.append("Compliance: ").append(getCompliance()).append(",");
if (getVerificationState() != null)
sb.append("VerificationState: ").append(getVerificationState()).append(",");
if (getWorkflowState() != null)
sb.append("WorkflowState: ").append(getWorkflowState()).append(",");
if (getWorkflow() != null)
sb.append("Workflow: ").append(getWorkflow()).append(",");
if (getRecordState() != null)
sb.append("RecordState: ").append(getRecordState()).append(",");
if (getRelatedFindings() != null)
sb.append("RelatedFindings: ").append(getRelatedFindings()).append(",");
if (getNote() != null)
sb.append("Note: ").append(getNote()).append(",");
if (getVulnerabilities() != null)
sb.append("Vulnerabilities: ").append(getVulnerabilities()).append(",");
if (getPatchSummary() != null)
sb.append("PatchSummary: ").append(getPatchSummary()).append(",");
if (getAction() != null)
sb.append("Action: ").append(getAction()).append(",");
if (getFindingProviderFields() != null)
sb.append("FindingProviderFields: ").append(getFindingProviderFields()).append(",");
if (getSample() != null)
sb.append("Sample: ").append(getSample()).append(",");
if (getGeneratorDetails() != null)
sb.append("GeneratorDetails: ").append(getGeneratorDetails());
sb.append("}");
return sb.toString();
}
@Override
public boolean equals(Object obj) {
if (this == obj)
return true;
if (obj == null)
return false;
if (obj instanceof AwsSecurityFinding == false)
return false;
AwsSecurityFinding other = (AwsSecurityFinding) obj;
if (other.getSchemaVersion() == null ^ this.getSchemaVersion() == null)
return false;
if (other.getSchemaVersion() != null && other.getSchemaVersion().equals(this.getSchemaVersion()) == false)
return false;
if (other.getId() == null ^ this.getId() == null)
return false;
if (other.getId() != null && other.getId().equals(this.getId()) == false)
return false;
if (other.getProductArn() == null ^ this.getProductArn() == null)
return false;
if (other.getProductArn() != null && other.getProductArn().equals(this.getProductArn()) == false)
return false;
if (other.getProductName() == null ^ this.getProductName() == null)
return false;
if (other.getProductName() != null && other.getProductName().equals(this.getProductName()) == false)
return false;
if (other.getCompanyName() == null ^ this.getCompanyName() == null)
return false;
if (other.getCompanyName() != null && other.getCompanyName().equals(this.getCompanyName()) == false)
return false;
if (other.getRegion() == null ^ this.getRegion() == null)
return false;
if (other.getRegion() != null && other.getRegion().equals(this.getRegion()) == false)
return false;
if (other.getGeneratorId() == null ^ this.getGeneratorId() == null)
return false;
if (other.getGeneratorId() != null && other.getGeneratorId().equals(this.getGeneratorId()) == false)
return false;
if (other.getAwsAccountId() == null ^ this.getAwsAccountId() == null)
return false;
if (other.getAwsAccountId() != null && other.getAwsAccountId().equals(this.getAwsAccountId()) == false)
return false;
if (other.getTypes() == null ^ this.getTypes() == null)
return false;
if (other.getTypes() != null && other.getTypes().equals(this.getTypes()) == false)
return false;
if (other.getFirstObservedAt() == null ^ this.getFirstObservedAt() == null)
return false;
if (other.getFirstObservedAt() != null && other.getFirstObservedAt().equals(this.getFirstObservedAt()) == false)
return false;
if (other.getLastObservedAt() == null ^ this.getLastObservedAt() == null)
return false;
if (other.getLastObservedAt() != null && other.getLastObservedAt().equals(this.getLastObservedAt()) == false)
return false;
if (other.getCreatedAt() == null ^ this.getCreatedAt() == null)
return false;
if (other.getCreatedAt() != null && other.getCreatedAt().equals(this.getCreatedAt()) == false)
return false;
if (other.getUpdatedAt() == null ^ this.getUpdatedAt() == null)
return false;
if (other.getUpdatedAt() != null && other.getUpdatedAt().equals(this.getUpdatedAt()) == 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.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.getTitle() == null ^ this.getTitle() == null)
return false;
if (other.getTitle() != null && other.getTitle().equals(this.getTitle()) == false)
return false;
if (other.getDescription() == null ^ this.getDescription() == null)
return false;
if (other.getDescription() != null && other.getDescription().equals(this.getDescription()) == false)
return false;
if (other.getRemediation() == null ^ this.getRemediation() == null)
return false;
if (other.getRemediation() != null && other.getRemediation().equals(this.getRemediation()) == false)
return false;
if (other.getSourceUrl() == null ^ this.getSourceUrl() == null)
return false;
if (other.getSourceUrl() != null && other.getSourceUrl().equals(this.getSourceUrl()) == false)
return false;
if (other.getProductFields() == null ^ this.getProductFields() == null)
return false;
if (other.getProductFields() != null && other.getProductFields().equals(this.getProductFields()) == false)
return false;
if (other.getUserDefinedFields() == null ^ this.getUserDefinedFields() == null)
return false;
if (other.getUserDefinedFields() != null && other.getUserDefinedFields().equals(this.getUserDefinedFields()) == false)
return false;
if (other.getMalware() == null ^ this.getMalware() == null)
return false;
if (other.getMalware() != null && other.getMalware().equals(this.getMalware()) == false)
return false;
if (other.getNetwork() == null ^ this.getNetwork() == null)
return false;
if (other.getNetwork() != null && other.getNetwork().equals(this.getNetwork()) == false)
return false;
if (other.getNetworkPath() == null ^ this.getNetworkPath() == null)
return false;
if (other.getNetworkPath() != null && other.getNetworkPath().equals(this.getNetworkPath()) == false)
return false;
if (other.getProcess() == null ^ this.getProcess() == null)
return false;
if (other.getProcess() != null && other.getProcess().equals(this.getProcess()) == false)
return false;
if (other.getThreats() == null ^ this.getThreats() == null)
return false;
if (other.getThreats() != null && other.getThreats().equals(this.getThreats()) == false)
return false;
if (other.getThreatIntelIndicators() == null ^ this.getThreatIntelIndicators() == null)
return false;
if (other.getThreatIntelIndicators() != null && other.getThreatIntelIndicators().equals(this.getThreatIntelIndicators()) == false)
return false;
if (other.getResources() == null ^ this.getResources() == null)
return false;
if (other.getResources() != null && other.getResources().equals(this.getResources()) == false)
return false;
if (other.getCompliance() == null ^ this.getCompliance() == null)
return false;
if (other.getCompliance() != null && other.getCompliance().equals(this.getCompliance()) == false)
return false;
if (other.getVerificationState() == null ^ this.getVerificationState() == null)
return false;
if (other.getVerificationState() != null && other.getVerificationState().equals(this.getVerificationState()) == false)
return false;
if (other.getWorkflowState() == null ^ this.getWorkflowState() == null)
return false;
if (other.getWorkflowState() != null && other.getWorkflowState().equals(this.getWorkflowState()) == false)
return false;
if (other.getWorkflow() == null ^ this.getWorkflow() == null)
return false;
if (other.getWorkflow() != null && other.getWorkflow().equals(this.getWorkflow()) == false)
return false;
if (other.getRecordState() == null ^ this.getRecordState() == null)
return false;
if (other.getRecordState() != null && other.getRecordState().equals(this.getRecordState()) == 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.getNote() == null ^ this.getNote() == null)
return false;
if (other.getNote() != null && other.getNote().equals(this.getNote()) == false)
return false;
if (other.getVulnerabilities() == null ^ this.getVulnerabilities() == null)
return false;
if (other.getVulnerabilities() != null && other.getVulnerabilities().equals(this.getVulnerabilities()) == false)
return false;
if (other.getPatchSummary() == null ^ this.getPatchSummary() == null)
return false;
if (other.getPatchSummary() != null && other.getPatchSummary().equals(this.getPatchSummary()) == false)
return false;
if (other.getAction() == null ^ this.getAction() == null)
return false;
if (other.getAction() != null && other.getAction().equals(this.getAction()) == false)
return false;
if (other.getFindingProviderFields() == null ^ this.getFindingProviderFields() == null)
return false;
if (other.getFindingProviderFields() != null && other.getFindingProviderFields().equals(this.getFindingProviderFields()) == false)
return false;
if (other.getSample() == null ^ this.getSample() == null)
return false;
if (other.getSample() != null && other.getSample().equals(this.getSample()) == false)
return false;
if (other.getGeneratorDetails() == null ^ this.getGeneratorDetails() == null)
return false;
if (other.getGeneratorDetails() != null && other.getGeneratorDetails().equals(this.getGeneratorDetails()) == false)
return false;
return true;
}
@Override
public int hashCode() {
final int prime = 31;
int hashCode = 1;
hashCode = prime * hashCode + ((getSchemaVersion() == null) ? 0 : getSchemaVersion().hashCode());
hashCode = prime * hashCode + ((getId() == null) ? 0 : getId().hashCode());
hashCode = prime * hashCode + ((getProductArn() == null) ? 0 : getProductArn().hashCode());
hashCode = prime * hashCode + ((getProductName() == null) ? 0 : getProductName().hashCode());
hashCode = prime * hashCode + ((getCompanyName() == null) ? 0 : getCompanyName().hashCode());
hashCode = prime * hashCode + ((getRegion() == null) ? 0 : getRegion().hashCode());
hashCode = prime * hashCode + ((getGeneratorId() == null) ? 0 : getGeneratorId().hashCode());
hashCode = prime * hashCode + ((getAwsAccountId() == null) ? 0 : getAwsAccountId().hashCode());
hashCode = prime * hashCode + ((getTypes() == null) ? 0 : getTypes().hashCode());
hashCode = prime * hashCode + ((getFirstObservedAt() == null) ? 0 : getFirstObservedAt().hashCode());
hashCode = prime * hashCode + ((getLastObservedAt() == null) ? 0 : getLastObservedAt().hashCode());
hashCode = prime * hashCode + ((getCreatedAt() == null) ? 0 : getCreatedAt().hashCode());
hashCode = prime * hashCode + ((getUpdatedAt() == null) ? 0 : getUpdatedAt().hashCode());
hashCode = prime * hashCode + ((getSeverity() == null) ? 0 : getSeverity().hashCode());
hashCode = prime * hashCode + ((getConfidence() == null) ? 0 : getConfidence().hashCode());
hashCode = prime * hashCode + ((getCriticality() == null) ? 0 : getCriticality().hashCode());
hashCode = prime * hashCode + ((getTitle() == null) ? 0 : getTitle().hashCode());
hashCode = prime * hashCode + ((getDescription() == null) ? 0 : getDescription().hashCode());
hashCode = prime * hashCode + ((getRemediation() == null) ? 0 : getRemediation().hashCode());
hashCode = prime * hashCode + ((getSourceUrl() == null) ? 0 : getSourceUrl().hashCode());
hashCode = prime * hashCode + ((getProductFields() == null) ? 0 : getProductFields().hashCode());
hashCode = prime * hashCode + ((getUserDefinedFields() == null) ? 0 : getUserDefinedFields().hashCode());
hashCode = prime * hashCode + ((getMalware() == null) ? 0 : getMalware().hashCode());
hashCode = prime * hashCode + ((getNetwork() == null) ? 0 : getNetwork().hashCode());
hashCode = prime * hashCode + ((getNetworkPath() == null) ? 0 : getNetworkPath().hashCode());
hashCode = prime * hashCode + ((getProcess() == null) ? 0 : getProcess().hashCode());
hashCode = prime * hashCode + ((getThreats() == null) ? 0 : getThreats().hashCode());
hashCode = prime * hashCode + ((getThreatIntelIndicators() == null) ? 0 : getThreatIntelIndicators().hashCode());
hashCode = prime * hashCode + ((getResources() == null) ? 0 : getResources().hashCode());
hashCode = prime * hashCode + ((getCompliance() == null) ? 0 : getCompliance().hashCode());
hashCode = prime * hashCode + ((getVerificationState() == null) ? 0 : getVerificationState().hashCode());
hashCode = prime * hashCode + ((getWorkflowState() == null) ? 0 : getWorkflowState().hashCode());
hashCode = prime * hashCode + ((getWorkflow() == null) ? 0 : getWorkflow().hashCode());
hashCode = prime * hashCode + ((getRecordState() == null) ? 0 : getRecordState().hashCode());
hashCode = prime * hashCode + ((getRelatedFindings() == null) ? 0 : getRelatedFindings().hashCode());
hashCode = prime * hashCode + ((getNote() == null) ? 0 : getNote().hashCode());
hashCode = prime * hashCode + ((getVulnerabilities() == null) ? 0 : getVulnerabilities().hashCode());
hashCode = prime * hashCode + ((getPatchSummary() == null) ? 0 : getPatchSummary().hashCode());
hashCode = prime * hashCode + ((getAction() == null) ? 0 : getAction().hashCode());
hashCode = prime * hashCode + ((getFindingProviderFields() == null) ? 0 : getFindingProviderFields().hashCode());
hashCode = prime * hashCode + ((getSample() == null) ? 0 : getSample().hashCode());
hashCode = prime * hashCode + ((getGeneratorDetails() == null) ? 0 : getGeneratorDetails().hashCode());
return hashCode;
}
@Override
public AwsSecurityFinding clone() {
try {
return (AwsSecurityFinding) 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.AwsSecurityFindingMarshaller.getInstance().marshall(this, protocolMarshaller);
}
}