com.amazonaws.services.guardduty.model.Scan Maven / Gradle / Ivy
Show all versions of aws-java-sdk-guardduty Show documentation
/*
* Copyright 2019-2024 Amazon.com, Inc. or its affiliates. All Rights Reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License"). You may not use this file except in compliance with
* the License. A copy of the License is located at
*
* http://aws.amazon.com/apache2.0
*
* or in the "license" file accompanying this file. This file is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR
* CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions
* and limitations under the License.
*/
package com.amazonaws.services.guardduty.model;
import java.io.Serializable;
import javax.annotation.Generated;
import com.amazonaws.protocol.StructuredPojo;
import com.amazonaws.protocol.ProtocolMarshaller;
/**
*
* Contains information about a malware scan.
*
*
* @see AWS API
* Documentation
*/
@Generated("com.amazonaws:aws-java-sdk-code-generator")
public class Scan implements Serializable, Cloneable, StructuredPojo {
/**
*
* The unique ID of the detector that the request is associated with.
*
*/
private String detectorId;
/**
*
* The unique detector ID of the administrator account that the request is associated with. Note that this value
* will be the same as the one used for DetectorId
if the account is an administrator.
*
*/
private String adminDetectorId;
/**
*
* The unique scan ID associated with a scan entry.
*
*/
private String scanId;
/**
*
* An enum value representing possible scan statuses.
*
*/
private String scanStatus;
/**
*
* Represents the reason for FAILED scan status.
*
*/
private String failureReason;
/**
*
* The timestamp of when the scan was triggered.
*
*/
private java.util.Date scanStartTime;
/**
*
* The timestamp of when the scan was finished.
*
*/
private java.util.Date scanEndTime;
/**
*
* Specifies the reason why the scan was initiated.
*
*/
private TriggerDetails triggerDetails;
/**
*
* Represents the resources that were scanned in the scan entry.
*
*/
private ResourceDetails resourceDetails;
/**
*
* Represents the result of the scan.
*
*/
private ScanResultDetails scanResultDetails;
/**
*
* The ID for the account that belongs to the scan.
*
*/
private String accountId;
/**
*
* Represents total bytes that were scanned.
*
*/
private Long totalBytes;
/**
*
* Represents the number of files that were scanned.
*
*/
private Long fileCount;
/**
*
* List of volumes that were attached to the original instance to be scanned.
*
*/
private java.util.List attachedVolumes;
/**
*
* Specifies the scan type that invoked the malware scan.
*
*/
private String scanType;
/**
*
* The unique ID of the detector that the request is associated with.
*
*
* @param detectorId
* The unique ID of the detector that the request is associated with.
*/
public void setDetectorId(String detectorId) {
this.detectorId = detectorId;
}
/**
*
* The unique ID of the detector that the request is associated with.
*
*
* @return The unique ID of the detector that the request is associated with.
*/
public String getDetectorId() {
return this.detectorId;
}
/**
*
* The unique ID of the detector that the request is associated with.
*
*
* @param detectorId
* The unique ID of the detector that the request is associated with.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public Scan withDetectorId(String detectorId) {
setDetectorId(detectorId);
return this;
}
/**
*
* The unique detector ID of the administrator account that the request is associated with. Note that this value
* will be the same as the one used for DetectorId
if the account is an administrator.
*
*
* @param adminDetectorId
* The unique detector ID of the administrator account that the request is associated with. Note that this
* value will be the same as the one used for DetectorId
if the account is an administrator.
*/
public void setAdminDetectorId(String adminDetectorId) {
this.adminDetectorId = adminDetectorId;
}
/**
*
* The unique detector ID of the administrator account that the request is associated with. Note that this value
* will be the same as the one used for DetectorId
if the account is an administrator.
*
*
* @return The unique detector ID of the administrator account that the request is associated with. Note that this
* value will be the same as the one used for DetectorId
if the account is an administrator.
*/
public String getAdminDetectorId() {
return this.adminDetectorId;
}
/**
*
* The unique detector ID of the administrator account that the request is associated with. Note that this value
* will be the same as the one used for DetectorId
if the account is an administrator.
*
*
* @param adminDetectorId
* The unique detector ID of the administrator account that the request is associated with. Note that this
* value will be the same as the one used for DetectorId
if the account is an administrator.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public Scan withAdminDetectorId(String adminDetectorId) {
setAdminDetectorId(adminDetectorId);
return this;
}
/**
*
* The unique scan ID associated with a scan entry.
*
*
* @param scanId
* The unique scan ID associated with a scan entry.
*/
public void setScanId(String scanId) {
this.scanId = scanId;
}
/**
*
* The unique scan ID associated with a scan entry.
*
*
* @return The unique scan ID associated with a scan entry.
*/
public String getScanId() {
return this.scanId;
}
/**
*
* The unique scan ID associated with a scan entry.
*
*
* @param scanId
* The unique scan ID associated with a scan entry.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public Scan withScanId(String scanId) {
setScanId(scanId);
return this;
}
/**
*
* An enum value representing possible scan statuses.
*
*
* @param scanStatus
* An enum value representing possible scan statuses.
* @see ScanStatus
*/
public void setScanStatus(String scanStatus) {
this.scanStatus = scanStatus;
}
/**
*
* An enum value representing possible scan statuses.
*
*
* @return An enum value representing possible scan statuses.
* @see ScanStatus
*/
public String getScanStatus() {
return this.scanStatus;
}
/**
*
* An enum value representing possible scan statuses.
*
*
* @param scanStatus
* An enum value representing possible scan statuses.
* @return Returns a reference to this object so that method calls can be chained together.
* @see ScanStatus
*/
public Scan withScanStatus(String scanStatus) {
setScanStatus(scanStatus);
return this;
}
/**
*
* An enum value representing possible scan statuses.
*
*
* @param scanStatus
* An enum value representing possible scan statuses.
* @return Returns a reference to this object so that method calls can be chained together.
* @see ScanStatus
*/
public Scan withScanStatus(ScanStatus scanStatus) {
this.scanStatus = scanStatus.toString();
return this;
}
/**
*
* Represents the reason for FAILED scan status.
*
*
* @param failureReason
* Represents the reason for FAILED scan status.
*/
public void setFailureReason(String failureReason) {
this.failureReason = failureReason;
}
/**
*
* Represents the reason for FAILED scan status.
*
*
* @return Represents the reason for FAILED scan status.
*/
public String getFailureReason() {
return this.failureReason;
}
/**
*
* Represents the reason for FAILED scan status.
*
*
* @param failureReason
* Represents the reason for FAILED scan status.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public Scan withFailureReason(String failureReason) {
setFailureReason(failureReason);
return this;
}
/**
*
* The timestamp of when the scan was triggered.
*
*
* @param scanStartTime
* The timestamp of when the scan was triggered.
*/
public void setScanStartTime(java.util.Date scanStartTime) {
this.scanStartTime = scanStartTime;
}
/**
*
* The timestamp of when the scan was triggered.
*
*
* @return The timestamp of when the scan was triggered.
*/
public java.util.Date getScanStartTime() {
return this.scanStartTime;
}
/**
*
* The timestamp of when the scan was triggered.
*
*
* @param scanStartTime
* The timestamp of when the scan was triggered.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public Scan withScanStartTime(java.util.Date scanStartTime) {
setScanStartTime(scanStartTime);
return this;
}
/**
*
* The timestamp of when the scan was finished.
*
*
* @param scanEndTime
* The timestamp of when the scan was finished.
*/
public void setScanEndTime(java.util.Date scanEndTime) {
this.scanEndTime = scanEndTime;
}
/**
*
* The timestamp of when the scan was finished.
*
*
* @return The timestamp of when the scan was finished.
*/
public java.util.Date getScanEndTime() {
return this.scanEndTime;
}
/**
*
* The timestamp of when the scan was finished.
*
*
* @param scanEndTime
* The timestamp of when the scan was finished.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public Scan withScanEndTime(java.util.Date scanEndTime) {
setScanEndTime(scanEndTime);
return this;
}
/**
*
* Specifies the reason why the scan was initiated.
*
*
* @param triggerDetails
* Specifies the reason why the scan was initiated.
*/
public void setTriggerDetails(TriggerDetails triggerDetails) {
this.triggerDetails = triggerDetails;
}
/**
*
* Specifies the reason why the scan was initiated.
*
*
* @return Specifies the reason why the scan was initiated.
*/
public TriggerDetails getTriggerDetails() {
return this.triggerDetails;
}
/**
*
* Specifies the reason why the scan was initiated.
*
*
* @param triggerDetails
* Specifies the reason why the scan was initiated.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public Scan withTriggerDetails(TriggerDetails triggerDetails) {
setTriggerDetails(triggerDetails);
return this;
}
/**
*
* Represents the resources that were scanned in the scan entry.
*
*
* @param resourceDetails
* Represents the resources that were scanned in the scan entry.
*/
public void setResourceDetails(ResourceDetails resourceDetails) {
this.resourceDetails = resourceDetails;
}
/**
*
* Represents the resources that were scanned in the scan entry.
*
*
* @return Represents the resources that were scanned in the scan entry.
*/
public ResourceDetails getResourceDetails() {
return this.resourceDetails;
}
/**
*
* Represents the resources that were scanned in the scan entry.
*
*
* @param resourceDetails
* Represents the resources that were scanned in the scan entry.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public Scan withResourceDetails(ResourceDetails resourceDetails) {
setResourceDetails(resourceDetails);
return this;
}
/**
*
* Represents the result of the scan.
*
*
* @param scanResultDetails
* Represents the result of the scan.
*/
public void setScanResultDetails(ScanResultDetails scanResultDetails) {
this.scanResultDetails = scanResultDetails;
}
/**
*
* Represents the result of the scan.
*
*
* @return Represents the result of the scan.
*/
public ScanResultDetails getScanResultDetails() {
return this.scanResultDetails;
}
/**
*
* Represents the result of the scan.
*
*
* @param scanResultDetails
* Represents the result of the scan.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public Scan withScanResultDetails(ScanResultDetails scanResultDetails) {
setScanResultDetails(scanResultDetails);
return this;
}
/**
*
* The ID for the account that belongs to the scan.
*
*
* @param accountId
* The ID for the account that belongs to the scan.
*/
public void setAccountId(String accountId) {
this.accountId = accountId;
}
/**
*
* The ID for the account that belongs to the scan.
*
*
* @return The ID for the account that belongs to the scan.
*/
public String getAccountId() {
return this.accountId;
}
/**
*
* The ID for the account that belongs to the scan.
*
*
* @param accountId
* The ID for the account that belongs to the scan.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public Scan withAccountId(String accountId) {
setAccountId(accountId);
return this;
}
/**
*
* Represents total bytes that were scanned.
*
*
* @param totalBytes
* Represents total bytes that were scanned.
*/
public void setTotalBytes(Long totalBytes) {
this.totalBytes = totalBytes;
}
/**
*
* Represents total bytes that were scanned.
*
*
* @return Represents total bytes that were scanned.
*/
public Long getTotalBytes() {
return this.totalBytes;
}
/**
*
* Represents total bytes that were scanned.
*
*
* @param totalBytes
* Represents total bytes that were scanned.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public Scan withTotalBytes(Long totalBytes) {
setTotalBytes(totalBytes);
return this;
}
/**
*
* Represents the number of files that were scanned.
*
*
* @param fileCount
* Represents the number of files that were scanned.
*/
public void setFileCount(Long fileCount) {
this.fileCount = fileCount;
}
/**
*
* Represents the number of files that were scanned.
*
*
* @return Represents the number of files that were scanned.
*/
public Long getFileCount() {
return this.fileCount;
}
/**
*
* Represents the number of files that were scanned.
*
*
* @param fileCount
* Represents the number of files that were scanned.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public Scan withFileCount(Long fileCount) {
setFileCount(fileCount);
return this;
}
/**
*
* List of volumes that were attached to the original instance to be scanned.
*
*
* @return List of volumes that were attached to the original instance to be scanned.
*/
public java.util.List getAttachedVolumes() {
return attachedVolumes;
}
/**
*
* List of volumes that were attached to the original instance to be scanned.
*
*
* @param attachedVolumes
* List of volumes that were attached to the original instance to be scanned.
*/
public void setAttachedVolumes(java.util.Collection attachedVolumes) {
if (attachedVolumes == null) {
this.attachedVolumes = null;
return;
}
this.attachedVolumes = new java.util.ArrayList(attachedVolumes);
}
/**
*
* List of volumes that were attached to the original instance to be scanned.
*
*
* NOTE: This method appends the values to the existing list (if any). Use
* {@link #setAttachedVolumes(java.util.Collection)} or {@link #withAttachedVolumes(java.util.Collection)} if you
* want to override the existing values.
*
*
* @param attachedVolumes
* List of volumes that were attached to the original instance to be scanned.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public Scan withAttachedVolumes(VolumeDetail... attachedVolumes) {
if (this.attachedVolumes == null) {
setAttachedVolumes(new java.util.ArrayList(attachedVolumes.length));
}
for (VolumeDetail ele : attachedVolumes) {
this.attachedVolumes.add(ele);
}
return this;
}
/**
*
* List of volumes that were attached to the original instance to be scanned.
*
*
* @param attachedVolumes
* List of volumes that were attached to the original instance to be scanned.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public Scan withAttachedVolumes(java.util.Collection attachedVolumes) {
setAttachedVolumes(attachedVolumes);
return this;
}
/**
*
* Specifies the scan type that invoked the malware scan.
*
*
* @param scanType
* Specifies the scan type that invoked the malware scan.
* @see ScanType
*/
public void setScanType(String scanType) {
this.scanType = scanType;
}
/**
*
* Specifies the scan type that invoked the malware scan.
*
*
* @return Specifies the scan type that invoked the malware scan.
* @see ScanType
*/
public String getScanType() {
return this.scanType;
}
/**
*
* Specifies the scan type that invoked the malware scan.
*
*
* @param scanType
* Specifies the scan type that invoked the malware scan.
* @return Returns a reference to this object so that method calls can be chained together.
* @see ScanType
*/
public Scan withScanType(String scanType) {
setScanType(scanType);
return this;
}
/**
*
* Specifies the scan type that invoked the malware scan.
*
*
* @param scanType
* Specifies the scan type that invoked the malware scan.
* @return Returns a reference to this object so that method calls can be chained together.
* @see ScanType
*/
public Scan withScanType(ScanType scanType) {
this.scanType = scanType.toString();
return this;
}
/**
* Returns a string representation of this object. This is useful for testing and debugging. Sensitive data will be
* redacted from this string using a placeholder value.
*
* @return A string representation of this object.
*
* @see java.lang.Object#toString()
*/
@Override
public String toString() {
StringBuilder sb = new StringBuilder();
sb.append("{");
if (getDetectorId() != null)
sb.append("DetectorId: ").append(getDetectorId()).append(",");
if (getAdminDetectorId() != null)
sb.append("AdminDetectorId: ").append(getAdminDetectorId()).append(",");
if (getScanId() != null)
sb.append("ScanId: ").append(getScanId()).append(",");
if (getScanStatus() != null)
sb.append("ScanStatus: ").append(getScanStatus()).append(",");
if (getFailureReason() != null)
sb.append("FailureReason: ").append(getFailureReason()).append(",");
if (getScanStartTime() != null)
sb.append("ScanStartTime: ").append(getScanStartTime()).append(",");
if (getScanEndTime() != null)
sb.append("ScanEndTime: ").append(getScanEndTime()).append(",");
if (getTriggerDetails() != null)
sb.append("TriggerDetails: ").append(getTriggerDetails()).append(",");
if (getResourceDetails() != null)
sb.append("ResourceDetails: ").append(getResourceDetails()).append(",");
if (getScanResultDetails() != null)
sb.append("ScanResultDetails: ").append(getScanResultDetails()).append(",");
if (getAccountId() != null)
sb.append("AccountId: ").append(getAccountId()).append(",");
if (getTotalBytes() != null)
sb.append("TotalBytes: ").append(getTotalBytes()).append(",");
if (getFileCount() != null)
sb.append("FileCount: ").append(getFileCount()).append(",");
if (getAttachedVolumes() != null)
sb.append("AttachedVolumes: ").append(getAttachedVolumes()).append(",");
if (getScanType() != null)
sb.append("ScanType: ").append(getScanType());
sb.append("}");
return sb.toString();
}
@Override
public boolean equals(Object obj) {
if (this == obj)
return true;
if (obj == null)
return false;
if (obj instanceof Scan == false)
return false;
Scan other = (Scan) obj;
if (other.getDetectorId() == null ^ this.getDetectorId() == null)
return false;
if (other.getDetectorId() != null && other.getDetectorId().equals(this.getDetectorId()) == false)
return false;
if (other.getAdminDetectorId() == null ^ this.getAdminDetectorId() == null)
return false;
if (other.getAdminDetectorId() != null && other.getAdminDetectorId().equals(this.getAdminDetectorId()) == false)
return false;
if (other.getScanId() == null ^ this.getScanId() == null)
return false;
if (other.getScanId() != null && other.getScanId().equals(this.getScanId()) == false)
return false;
if (other.getScanStatus() == null ^ this.getScanStatus() == null)
return false;
if (other.getScanStatus() != null && other.getScanStatus().equals(this.getScanStatus()) == false)
return false;
if (other.getFailureReason() == null ^ this.getFailureReason() == null)
return false;
if (other.getFailureReason() != null && other.getFailureReason().equals(this.getFailureReason()) == false)
return false;
if (other.getScanStartTime() == null ^ this.getScanStartTime() == null)
return false;
if (other.getScanStartTime() != null && other.getScanStartTime().equals(this.getScanStartTime()) == false)
return false;
if (other.getScanEndTime() == null ^ this.getScanEndTime() == null)
return false;
if (other.getScanEndTime() != null && other.getScanEndTime().equals(this.getScanEndTime()) == false)
return false;
if (other.getTriggerDetails() == null ^ this.getTriggerDetails() == null)
return false;
if (other.getTriggerDetails() != null && other.getTriggerDetails().equals(this.getTriggerDetails()) == false)
return false;
if (other.getResourceDetails() == null ^ this.getResourceDetails() == null)
return false;
if (other.getResourceDetails() != null && other.getResourceDetails().equals(this.getResourceDetails()) == false)
return false;
if (other.getScanResultDetails() == null ^ this.getScanResultDetails() == null)
return false;
if (other.getScanResultDetails() != null && other.getScanResultDetails().equals(this.getScanResultDetails()) == false)
return false;
if (other.getAccountId() == null ^ this.getAccountId() == null)
return false;
if (other.getAccountId() != null && other.getAccountId().equals(this.getAccountId()) == false)
return false;
if (other.getTotalBytes() == null ^ this.getTotalBytes() == null)
return false;
if (other.getTotalBytes() != null && other.getTotalBytes().equals(this.getTotalBytes()) == false)
return false;
if (other.getFileCount() == null ^ this.getFileCount() == null)
return false;
if (other.getFileCount() != null && other.getFileCount().equals(this.getFileCount()) == false)
return false;
if (other.getAttachedVolumes() == null ^ this.getAttachedVolumes() == null)
return false;
if (other.getAttachedVolumes() != null && other.getAttachedVolumes().equals(this.getAttachedVolumes()) == false)
return false;
if (other.getScanType() == null ^ this.getScanType() == null)
return false;
if (other.getScanType() != null && other.getScanType().equals(this.getScanType()) == false)
return false;
return true;
}
@Override
public int hashCode() {
final int prime = 31;
int hashCode = 1;
hashCode = prime * hashCode + ((getDetectorId() == null) ? 0 : getDetectorId().hashCode());
hashCode = prime * hashCode + ((getAdminDetectorId() == null) ? 0 : getAdminDetectorId().hashCode());
hashCode = prime * hashCode + ((getScanId() == null) ? 0 : getScanId().hashCode());
hashCode = prime * hashCode + ((getScanStatus() == null) ? 0 : getScanStatus().hashCode());
hashCode = prime * hashCode + ((getFailureReason() == null) ? 0 : getFailureReason().hashCode());
hashCode = prime * hashCode + ((getScanStartTime() == null) ? 0 : getScanStartTime().hashCode());
hashCode = prime * hashCode + ((getScanEndTime() == null) ? 0 : getScanEndTime().hashCode());
hashCode = prime * hashCode + ((getTriggerDetails() == null) ? 0 : getTriggerDetails().hashCode());
hashCode = prime * hashCode + ((getResourceDetails() == null) ? 0 : getResourceDetails().hashCode());
hashCode = prime * hashCode + ((getScanResultDetails() == null) ? 0 : getScanResultDetails().hashCode());
hashCode = prime * hashCode + ((getAccountId() == null) ? 0 : getAccountId().hashCode());
hashCode = prime * hashCode + ((getTotalBytes() == null) ? 0 : getTotalBytes().hashCode());
hashCode = prime * hashCode + ((getFileCount() == null) ? 0 : getFileCount().hashCode());
hashCode = prime * hashCode + ((getAttachedVolumes() == null) ? 0 : getAttachedVolumes().hashCode());
hashCode = prime * hashCode + ((getScanType() == null) ? 0 : getScanType().hashCode());
return hashCode;
}
@Override
public Scan clone() {
try {
return (Scan) 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.guardduty.model.transform.ScanMarshaller.getInstance().marshall(this, protocolMarshaller);
}
}