com.amazonaws.services.guardduty.model.RuntimeContext 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;
/**
*
* Additional information about the suspicious activity.
*
*
* @see AWS API
* Documentation
*/
@Generated("com.amazonaws:aws-java-sdk-code-generator")
public class RuntimeContext implements Serializable, Cloneable, StructuredPojo {
/**
*
* Information about the process that modified the current process. This is available for multiple finding types.
*
*/
private ProcessDetails modifyingProcess;
/**
*
* The timestamp at which the process modified the current process. The timestamp is in UTC date string format.
*
*/
private java.util.Date modifiedAt;
/**
*
* The path to the script that was executed.
*
*/
private String scriptPath;
/**
*
* The path to the new library that was loaded.
*
*/
private String libraryPath;
/**
*
* The value of the LD_PRELOAD environment variable.
*
*/
private String ldPreloadValue;
/**
*
* The path to the docket socket that was accessed.
*
*/
private String socketPath;
/**
*
* The path to the leveraged runc
implementation.
*
*/
private String runcBinaryPath;
/**
*
* The path in the container that modified the release agent file.
*
*/
private String releaseAgentPath;
/**
*
* The path on the host that is mounted by the container.
*
*/
private String mountSource;
/**
*
* The path in the container that is mapped to the host directory.
*
*/
private String mountTarget;
/**
*
* Represents the type of mounted fileSystem.
*
*/
private String fileSystemType;
/**
*
* Represents options that control the behavior of a runtime operation or action. For example, a filesystem mount
* operation may contain a read-only flag.
*
*/
private java.util.List flags;
/**
*
* The name of the module loaded into the kernel.
*
*/
private String moduleName;
/**
*
* The path to the module loaded into the kernel.
*
*/
private String moduleFilePath;
/**
*
* The SHA256
hash of the module.
*
*/
private String moduleSha256;
/**
*
* The path to the modified shell history file.
*
*/
private String shellHistoryFilePath;
/**
*
* Information about the process that had its memory overwritten by the current process.
*
*/
private ProcessDetails targetProcess;
/**
*
* Represents the communication protocol associated with the address. For example, the address family
* AF_INET
is used for IP version of 4 protocol.
*
*/
private String addressFamily;
/**
*
* Specifies a particular protocol within the address family. Usually there is a single protocol in address
* families. For example, the address family AF_INET
only has the IP protocol.
*
*/
private Integer ianaProtocolNumber;
/**
*
* Specifies the Region of a process's address space such as stack and heap.
*
*/
private java.util.List memoryRegions;
/**
*
* Information about the process that modified the current process. This is available for multiple finding types.
*
*
* @param modifyingProcess
* Information about the process that modified the current process. This is available for multiple finding
* types.
*/
public void setModifyingProcess(ProcessDetails modifyingProcess) {
this.modifyingProcess = modifyingProcess;
}
/**
*
* Information about the process that modified the current process. This is available for multiple finding types.
*
*
* @return Information about the process that modified the current process. This is available for multiple finding
* types.
*/
public ProcessDetails getModifyingProcess() {
return this.modifyingProcess;
}
/**
*
* Information about the process that modified the current process. This is available for multiple finding types.
*
*
* @param modifyingProcess
* Information about the process that modified the current process. This is available for multiple finding
* types.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public RuntimeContext withModifyingProcess(ProcessDetails modifyingProcess) {
setModifyingProcess(modifyingProcess);
return this;
}
/**
*
* The timestamp at which the process modified the current process. The timestamp is in UTC date string format.
*
*
* @param modifiedAt
* The timestamp at which the process modified the current process. The timestamp is in UTC date string
* format.
*/
public void setModifiedAt(java.util.Date modifiedAt) {
this.modifiedAt = modifiedAt;
}
/**
*
* The timestamp at which the process modified the current process. The timestamp is in UTC date string format.
*
*
* @return The timestamp at which the process modified the current process. The timestamp is in UTC date string
* format.
*/
public java.util.Date getModifiedAt() {
return this.modifiedAt;
}
/**
*
* The timestamp at which the process modified the current process. The timestamp is in UTC date string format.
*
*
* @param modifiedAt
* The timestamp at which the process modified the current process. The timestamp is in UTC date string
* format.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public RuntimeContext withModifiedAt(java.util.Date modifiedAt) {
setModifiedAt(modifiedAt);
return this;
}
/**
*
* The path to the script that was executed.
*
*
* @param scriptPath
* The path to the script that was executed.
*/
public void setScriptPath(String scriptPath) {
this.scriptPath = scriptPath;
}
/**
*
* The path to the script that was executed.
*
*
* @return The path to the script that was executed.
*/
public String getScriptPath() {
return this.scriptPath;
}
/**
*
* The path to the script that was executed.
*
*
* @param scriptPath
* The path to the script that was executed.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public RuntimeContext withScriptPath(String scriptPath) {
setScriptPath(scriptPath);
return this;
}
/**
*
* The path to the new library that was loaded.
*
*
* @param libraryPath
* The path to the new library that was loaded.
*/
public void setLibraryPath(String libraryPath) {
this.libraryPath = libraryPath;
}
/**
*
* The path to the new library that was loaded.
*
*
* @return The path to the new library that was loaded.
*/
public String getLibraryPath() {
return this.libraryPath;
}
/**
*
* The path to the new library that was loaded.
*
*
* @param libraryPath
* The path to the new library that was loaded.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public RuntimeContext withLibraryPath(String libraryPath) {
setLibraryPath(libraryPath);
return this;
}
/**
*
* The value of the LD_PRELOAD environment variable.
*
*
* @param ldPreloadValue
* The value of the LD_PRELOAD environment variable.
*/
public void setLdPreloadValue(String ldPreloadValue) {
this.ldPreloadValue = ldPreloadValue;
}
/**
*
* The value of the LD_PRELOAD environment variable.
*
*
* @return The value of the LD_PRELOAD environment variable.
*/
public String getLdPreloadValue() {
return this.ldPreloadValue;
}
/**
*
* The value of the LD_PRELOAD environment variable.
*
*
* @param ldPreloadValue
* The value of the LD_PRELOAD environment variable.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public RuntimeContext withLdPreloadValue(String ldPreloadValue) {
setLdPreloadValue(ldPreloadValue);
return this;
}
/**
*
* The path to the docket socket that was accessed.
*
*
* @param socketPath
* The path to the docket socket that was accessed.
*/
public void setSocketPath(String socketPath) {
this.socketPath = socketPath;
}
/**
*
* The path to the docket socket that was accessed.
*
*
* @return The path to the docket socket that was accessed.
*/
public String getSocketPath() {
return this.socketPath;
}
/**
*
* The path to the docket socket that was accessed.
*
*
* @param socketPath
* The path to the docket socket that was accessed.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public RuntimeContext withSocketPath(String socketPath) {
setSocketPath(socketPath);
return this;
}
/**
*
* The path to the leveraged runc
implementation.
*
*
* @param runcBinaryPath
* The path to the leveraged runc
implementation.
*/
public void setRuncBinaryPath(String runcBinaryPath) {
this.runcBinaryPath = runcBinaryPath;
}
/**
*
* The path to the leveraged runc
implementation.
*
*
* @return The path to the leveraged runc
implementation.
*/
public String getRuncBinaryPath() {
return this.runcBinaryPath;
}
/**
*
* The path to the leveraged runc
implementation.
*
*
* @param runcBinaryPath
* The path to the leveraged runc
implementation.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public RuntimeContext withRuncBinaryPath(String runcBinaryPath) {
setRuncBinaryPath(runcBinaryPath);
return this;
}
/**
*
* The path in the container that modified the release agent file.
*
*
* @param releaseAgentPath
* The path in the container that modified the release agent file.
*/
public void setReleaseAgentPath(String releaseAgentPath) {
this.releaseAgentPath = releaseAgentPath;
}
/**
*
* The path in the container that modified the release agent file.
*
*
* @return The path in the container that modified the release agent file.
*/
public String getReleaseAgentPath() {
return this.releaseAgentPath;
}
/**
*
* The path in the container that modified the release agent file.
*
*
* @param releaseAgentPath
* The path in the container that modified the release agent file.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public RuntimeContext withReleaseAgentPath(String releaseAgentPath) {
setReleaseAgentPath(releaseAgentPath);
return this;
}
/**
*
* The path on the host that is mounted by the container.
*
*
* @param mountSource
* The path on the host that is mounted by the container.
*/
public void setMountSource(String mountSource) {
this.mountSource = mountSource;
}
/**
*
* The path on the host that is mounted by the container.
*
*
* @return The path on the host that is mounted by the container.
*/
public String getMountSource() {
return this.mountSource;
}
/**
*
* The path on the host that is mounted by the container.
*
*
* @param mountSource
* The path on the host that is mounted by the container.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public RuntimeContext withMountSource(String mountSource) {
setMountSource(mountSource);
return this;
}
/**
*
* The path in the container that is mapped to the host directory.
*
*
* @param mountTarget
* The path in the container that is mapped to the host directory.
*/
public void setMountTarget(String mountTarget) {
this.mountTarget = mountTarget;
}
/**
*
* The path in the container that is mapped to the host directory.
*
*
* @return The path in the container that is mapped to the host directory.
*/
public String getMountTarget() {
return this.mountTarget;
}
/**
*
* The path in the container that is mapped to the host directory.
*
*
* @param mountTarget
* The path in the container that is mapped to the host directory.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public RuntimeContext withMountTarget(String mountTarget) {
setMountTarget(mountTarget);
return this;
}
/**
*
* Represents the type of mounted fileSystem.
*
*
* @param fileSystemType
* Represents the type of mounted fileSystem.
*/
public void setFileSystemType(String fileSystemType) {
this.fileSystemType = fileSystemType;
}
/**
*
* Represents the type of mounted fileSystem.
*
*
* @return Represents the type of mounted fileSystem.
*/
public String getFileSystemType() {
return this.fileSystemType;
}
/**
*
* Represents the type of mounted fileSystem.
*
*
* @param fileSystemType
* Represents the type of mounted fileSystem.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public RuntimeContext withFileSystemType(String fileSystemType) {
setFileSystemType(fileSystemType);
return this;
}
/**
*
* Represents options that control the behavior of a runtime operation or action. For example, a filesystem mount
* operation may contain a read-only flag.
*
*
* @return Represents options that control the behavior of a runtime operation or action. For example, a filesystem
* mount operation may contain a read-only flag.
*/
public java.util.List getFlags() {
return flags;
}
/**
*
* Represents options that control the behavior of a runtime operation or action. For example, a filesystem mount
* operation may contain a read-only flag.
*
*
* @param flags
* Represents options that control the behavior of a runtime operation or action. For example, a filesystem
* mount operation may contain a read-only flag.
*/
public void setFlags(java.util.Collection flags) {
if (flags == null) {
this.flags = null;
return;
}
this.flags = new java.util.ArrayList(flags);
}
/**
*
* Represents options that control the behavior of a runtime operation or action. For example, a filesystem mount
* operation may contain a read-only flag.
*
*
* NOTE: This method appends the values to the existing list (if any). Use
* {@link #setFlags(java.util.Collection)} or {@link #withFlags(java.util.Collection)} if you want to override the
* existing values.
*
*
* @param flags
* Represents options that control the behavior of a runtime operation or action. For example, a filesystem
* mount operation may contain a read-only flag.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public RuntimeContext withFlags(String... flags) {
if (this.flags == null) {
setFlags(new java.util.ArrayList(flags.length));
}
for (String ele : flags) {
this.flags.add(ele);
}
return this;
}
/**
*
* Represents options that control the behavior of a runtime operation or action. For example, a filesystem mount
* operation may contain a read-only flag.
*
*
* @param flags
* Represents options that control the behavior of a runtime operation or action. For example, a filesystem
* mount operation may contain a read-only flag.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public RuntimeContext withFlags(java.util.Collection flags) {
setFlags(flags);
return this;
}
/**
*
* The name of the module loaded into the kernel.
*
*
* @param moduleName
* The name of the module loaded into the kernel.
*/
public void setModuleName(String moduleName) {
this.moduleName = moduleName;
}
/**
*
* The name of the module loaded into the kernel.
*
*
* @return The name of the module loaded into the kernel.
*/
public String getModuleName() {
return this.moduleName;
}
/**
*
* The name of the module loaded into the kernel.
*
*
* @param moduleName
* The name of the module loaded into the kernel.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public RuntimeContext withModuleName(String moduleName) {
setModuleName(moduleName);
return this;
}
/**
*
* The path to the module loaded into the kernel.
*
*
* @param moduleFilePath
* The path to the module loaded into the kernel.
*/
public void setModuleFilePath(String moduleFilePath) {
this.moduleFilePath = moduleFilePath;
}
/**
*
* The path to the module loaded into the kernel.
*
*
* @return The path to the module loaded into the kernel.
*/
public String getModuleFilePath() {
return this.moduleFilePath;
}
/**
*
* The path to the module loaded into the kernel.
*
*
* @param moduleFilePath
* The path to the module loaded into the kernel.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public RuntimeContext withModuleFilePath(String moduleFilePath) {
setModuleFilePath(moduleFilePath);
return this;
}
/**
*
* The SHA256
hash of the module.
*
*
* @param moduleSha256
* The SHA256
hash of the module.
*/
public void setModuleSha256(String moduleSha256) {
this.moduleSha256 = moduleSha256;
}
/**
*
* The SHA256
hash of the module.
*
*
* @return The SHA256
hash of the module.
*/
public String getModuleSha256() {
return this.moduleSha256;
}
/**
*
* The SHA256
hash of the module.
*
*
* @param moduleSha256
* The SHA256
hash of the module.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public RuntimeContext withModuleSha256(String moduleSha256) {
setModuleSha256(moduleSha256);
return this;
}
/**
*
* The path to the modified shell history file.
*
*
* @param shellHistoryFilePath
* The path to the modified shell history file.
*/
public void setShellHistoryFilePath(String shellHistoryFilePath) {
this.shellHistoryFilePath = shellHistoryFilePath;
}
/**
*
* The path to the modified shell history file.
*
*
* @return The path to the modified shell history file.
*/
public String getShellHistoryFilePath() {
return this.shellHistoryFilePath;
}
/**
*
* The path to the modified shell history file.
*
*
* @param shellHistoryFilePath
* The path to the modified shell history file.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public RuntimeContext withShellHistoryFilePath(String shellHistoryFilePath) {
setShellHistoryFilePath(shellHistoryFilePath);
return this;
}
/**
*
* Information about the process that had its memory overwritten by the current process.
*
*
* @param targetProcess
* Information about the process that had its memory overwritten by the current process.
*/
public void setTargetProcess(ProcessDetails targetProcess) {
this.targetProcess = targetProcess;
}
/**
*
* Information about the process that had its memory overwritten by the current process.
*
*
* @return Information about the process that had its memory overwritten by the current process.
*/
public ProcessDetails getTargetProcess() {
return this.targetProcess;
}
/**
*
* Information about the process that had its memory overwritten by the current process.
*
*
* @param targetProcess
* Information about the process that had its memory overwritten by the current process.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public RuntimeContext withTargetProcess(ProcessDetails targetProcess) {
setTargetProcess(targetProcess);
return this;
}
/**
*
* Represents the communication protocol associated with the address. For example, the address family
* AF_INET
is used for IP version of 4 protocol.
*
*
* @param addressFamily
* Represents the communication protocol associated with the address. For example, the address family
* AF_INET
is used for IP version of 4 protocol.
*/
public void setAddressFamily(String addressFamily) {
this.addressFamily = addressFamily;
}
/**
*
* Represents the communication protocol associated with the address. For example, the address family
* AF_INET
is used for IP version of 4 protocol.
*
*
* @return Represents the communication protocol associated with the address. For example, the address family
* AF_INET
is used for IP version of 4 protocol.
*/
public String getAddressFamily() {
return this.addressFamily;
}
/**
*
* Represents the communication protocol associated with the address. For example, the address family
* AF_INET
is used for IP version of 4 protocol.
*
*
* @param addressFamily
* Represents the communication protocol associated with the address. For example, the address family
* AF_INET
is used for IP version of 4 protocol.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public RuntimeContext withAddressFamily(String addressFamily) {
setAddressFamily(addressFamily);
return this;
}
/**
*
* Specifies a particular protocol within the address family. Usually there is a single protocol in address
* families. For example, the address family AF_INET
only has the IP protocol.
*
*
* @param ianaProtocolNumber
* Specifies a particular protocol within the address family. Usually there is a single protocol in address
* families. For example, the address family AF_INET
only has the IP protocol.
*/
public void setIanaProtocolNumber(Integer ianaProtocolNumber) {
this.ianaProtocolNumber = ianaProtocolNumber;
}
/**
*
* Specifies a particular protocol within the address family. Usually there is a single protocol in address
* families. For example, the address family AF_INET
only has the IP protocol.
*
*
* @return Specifies a particular protocol within the address family. Usually there is a single protocol in address
* families. For example, the address family AF_INET
only has the IP protocol.
*/
public Integer getIanaProtocolNumber() {
return this.ianaProtocolNumber;
}
/**
*
* Specifies a particular protocol within the address family. Usually there is a single protocol in address
* families. For example, the address family AF_INET
only has the IP protocol.
*
*
* @param ianaProtocolNumber
* Specifies a particular protocol within the address family. Usually there is a single protocol in address
* families. For example, the address family AF_INET
only has the IP protocol.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public RuntimeContext withIanaProtocolNumber(Integer ianaProtocolNumber) {
setIanaProtocolNumber(ianaProtocolNumber);
return this;
}
/**
*
* Specifies the Region of a process's address space such as stack and heap.
*
*
* @return Specifies the Region of a process's address space such as stack and heap.
*/
public java.util.List getMemoryRegions() {
return memoryRegions;
}
/**
*
* Specifies the Region of a process's address space such as stack and heap.
*
*
* @param memoryRegions
* Specifies the Region of a process's address space such as stack and heap.
*/
public void setMemoryRegions(java.util.Collection memoryRegions) {
if (memoryRegions == null) {
this.memoryRegions = null;
return;
}
this.memoryRegions = new java.util.ArrayList(memoryRegions);
}
/**
*
* Specifies the Region of a process's address space such as stack and heap.
*
*
* NOTE: This method appends the values to the existing list (if any). Use
* {@link #setMemoryRegions(java.util.Collection)} or {@link #withMemoryRegions(java.util.Collection)} if you want
* to override the existing values.
*
*
* @param memoryRegions
* Specifies the Region of a process's address space such as stack and heap.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public RuntimeContext withMemoryRegions(String... memoryRegions) {
if (this.memoryRegions == null) {
setMemoryRegions(new java.util.ArrayList(memoryRegions.length));
}
for (String ele : memoryRegions) {
this.memoryRegions.add(ele);
}
return this;
}
/**
*
* Specifies the Region of a process's address space such as stack and heap.
*
*
* @param memoryRegions
* Specifies the Region of a process's address space such as stack and heap.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public RuntimeContext withMemoryRegions(java.util.Collection memoryRegions) {
setMemoryRegions(memoryRegions);
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 (getModifyingProcess() != null)
sb.append("ModifyingProcess: ").append(getModifyingProcess()).append(",");
if (getModifiedAt() != null)
sb.append("ModifiedAt: ").append(getModifiedAt()).append(",");
if (getScriptPath() != null)
sb.append("ScriptPath: ").append(getScriptPath()).append(",");
if (getLibraryPath() != null)
sb.append("LibraryPath: ").append(getLibraryPath()).append(",");
if (getLdPreloadValue() != null)
sb.append("LdPreloadValue: ").append(getLdPreloadValue()).append(",");
if (getSocketPath() != null)
sb.append("SocketPath: ").append(getSocketPath()).append(",");
if (getRuncBinaryPath() != null)
sb.append("RuncBinaryPath: ").append(getRuncBinaryPath()).append(",");
if (getReleaseAgentPath() != null)
sb.append("ReleaseAgentPath: ").append(getReleaseAgentPath()).append(",");
if (getMountSource() != null)
sb.append("MountSource: ").append(getMountSource()).append(",");
if (getMountTarget() != null)
sb.append("MountTarget: ").append(getMountTarget()).append(",");
if (getFileSystemType() != null)
sb.append("FileSystemType: ").append(getFileSystemType()).append(",");
if (getFlags() != null)
sb.append("Flags: ").append(getFlags()).append(",");
if (getModuleName() != null)
sb.append("ModuleName: ").append(getModuleName()).append(",");
if (getModuleFilePath() != null)
sb.append("ModuleFilePath: ").append(getModuleFilePath()).append(",");
if (getModuleSha256() != null)
sb.append("ModuleSha256: ").append(getModuleSha256()).append(",");
if (getShellHistoryFilePath() != null)
sb.append("ShellHistoryFilePath: ").append(getShellHistoryFilePath()).append(",");
if (getTargetProcess() != null)
sb.append("TargetProcess: ").append(getTargetProcess()).append(",");
if (getAddressFamily() != null)
sb.append("AddressFamily: ").append(getAddressFamily()).append(",");
if (getIanaProtocolNumber() != null)
sb.append("IanaProtocolNumber: ").append(getIanaProtocolNumber()).append(",");
if (getMemoryRegions() != null)
sb.append("MemoryRegions: ").append(getMemoryRegions());
sb.append("}");
return sb.toString();
}
@Override
public boolean equals(Object obj) {
if (this == obj)
return true;
if (obj == null)
return false;
if (obj instanceof RuntimeContext == false)
return false;
RuntimeContext other = (RuntimeContext) obj;
if (other.getModifyingProcess() == null ^ this.getModifyingProcess() == null)
return false;
if (other.getModifyingProcess() != null && other.getModifyingProcess().equals(this.getModifyingProcess()) == false)
return false;
if (other.getModifiedAt() == null ^ this.getModifiedAt() == null)
return false;
if (other.getModifiedAt() != null && other.getModifiedAt().equals(this.getModifiedAt()) == false)
return false;
if (other.getScriptPath() == null ^ this.getScriptPath() == null)
return false;
if (other.getScriptPath() != null && other.getScriptPath().equals(this.getScriptPath()) == false)
return false;
if (other.getLibraryPath() == null ^ this.getLibraryPath() == null)
return false;
if (other.getLibraryPath() != null && other.getLibraryPath().equals(this.getLibraryPath()) == false)
return false;
if (other.getLdPreloadValue() == null ^ this.getLdPreloadValue() == null)
return false;
if (other.getLdPreloadValue() != null && other.getLdPreloadValue().equals(this.getLdPreloadValue()) == false)
return false;
if (other.getSocketPath() == null ^ this.getSocketPath() == null)
return false;
if (other.getSocketPath() != null && other.getSocketPath().equals(this.getSocketPath()) == false)
return false;
if (other.getRuncBinaryPath() == null ^ this.getRuncBinaryPath() == null)
return false;
if (other.getRuncBinaryPath() != null && other.getRuncBinaryPath().equals(this.getRuncBinaryPath()) == false)
return false;
if (other.getReleaseAgentPath() == null ^ this.getReleaseAgentPath() == null)
return false;
if (other.getReleaseAgentPath() != null && other.getReleaseAgentPath().equals(this.getReleaseAgentPath()) == false)
return false;
if (other.getMountSource() == null ^ this.getMountSource() == null)
return false;
if (other.getMountSource() != null && other.getMountSource().equals(this.getMountSource()) == false)
return false;
if (other.getMountTarget() == null ^ this.getMountTarget() == null)
return false;
if (other.getMountTarget() != null && other.getMountTarget().equals(this.getMountTarget()) == false)
return false;
if (other.getFileSystemType() == null ^ this.getFileSystemType() == null)
return false;
if (other.getFileSystemType() != null && other.getFileSystemType().equals(this.getFileSystemType()) == false)
return false;
if (other.getFlags() == null ^ this.getFlags() == null)
return false;
if (other.getFlags() != null && other.getFlags().equals(this.getFlags()) == false)
return false;
if (other.getModuleName() == null ^ this.getModuleName() == null)
return false;
if (other.getModuleName() != null && other.getModuleName().equals(this.getModuleName()) == false)
return false;
if (other.getModuleFilePath() == null ^ this.getModuleFilePath() == null)
return false;
if (other.getModuleFilePath() != null && other.getModuleFilePath().equals(this.getModuleFilePath()) == false)
return false;
if (other.getModuleSha256() == null ^ this.getModuleSha256() == null)
return false;
if (other.getModuleSha256() != null && other.getModuleSha256().equals(this.getModuleSha256()) == false)
return false;
if (other.getShellHistoryFilePath() == null ^ this.getShellHistoryFilePath() == null)
return false;
if (other.getShellHistoryFilePath() != null && other.getShellHistoryFilePath().equals(this.getShellHistoryFilePath()) == false)
return false;
if (other.getTargetProcess() == null ^ this.getTargetProcess() == null)
return false;
if (other.getTargetProcess() != null && other.getTargetProcess().equals(this.getTargetProcess()) == false)
return false;
if (other.getAddressFamily() == null ^ this.getAddressFamily() == null)
return false;
if (other.getAddressFamily() != null && other.getAddressFamily().equals(this.getAddressFamily()) == false)
return false;
if (other.getIanaProtocolNumber() == null ^ this.getIanaProtocolNumber() == null)
return false;
if (other.getIanaProtocolNumber() != null && other.getIanaProtocolNumber().equals(this.getIanaProtocolNumber()) == false)
return false;
if (other.getMemoryRegions() == null ^ this.getMemoryRegions() == null)
return false;
if (other.getMemoryRegions() != null && other.getMemoryRegions().equals(this.getMemoryRegions()) == false)
return false;
return true;
}
@Override
public int hashCode() {
final int prime = 31;
int hashCode = 1;
hashCode = prime * hashCode + ((getModifyingProcess() == null) ? 0 : getModifyingProcess().hashCode());
hashCode = prime * hashCode + ((getModifiedAt() == null) ? 0 : getModifiedAt().hashCode());
hashCode = prime * hashCode + ((getScriptPath() == null) ? 0 : getScriptPath().hashCode());
hashCode = prime * hashCode + ((getLibraryPath() == null) ? 0 : getLibraryPath().hashCode());
hashCode = prime * hashCode + ((getLdPreloadValue() == null) ? 0 : getLdPreloadValue().hashCode());
hashCode = prime * hashCode + ((getSocketPath() == null) ? 0 : getSocketPath().hashCode());
hashCode = prime * hashCode + ((getRuncBinaryPath() == null) ? 0 : getRuncBinaryPath().hashCode());
hashCode = prime * hashCode + ((getReleaseAgentPath() == null) ? 0 : getReleaseAgentPath().hashCode());
hashCode = prime * hashCode + ((getMountSource() == null) ? 0 : getMountSource().hashCode());
hashCode = prime * hashCode + ((getMountTarget() == null) ? 0 : getMountTarget().hashCode());
hashCode = prime * hashCode + ((getFileSystemType() == null) ? 0 : getFileSystemType().hashCode());
hashCode = prime * hashCode + ((getFlags() == null) ? 0 : getFlags().hashCode());
hashCode = prime * hashCode + ((getModuleName() == null) ? 0 : getModuleName().hashCode());
hashCode = prime * hashCode + ((getModuleFilePath() == null) ? 0 : getModuleFilePath().hashCode());
hashCode = prime * hashCode + ((getModuleSha256() == null) ? 0 : getModuleSha256().hashCode());
hashCode = prime * hashCode + ((getShellHistoryFilePath() == null) ? 0 : getShellHistoryFilePath().hashCode());
hashCode = prime * hashCode + ((getTargetProcess() == null) ? 0 : getTargetProcess().hashCode());
hashCode = prime * hashCode + ((getAddressFamily() == null) ? 0 : getAddressFamily().hashCode());
hashCode = prime * hashCode + ((getIanaProtocolNumber() == null) ? 0 : getIanaProtocolNumber().hashCode());
hashCode = prime * hashCode + ((getMemoryRegions() == null) ? 0 : getMemoryRegions().hashCode());
return hashCode;
}
@Override
public RuntimeContext clone() {
try {
return (RuntimeContext) 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.RuntimeContextMarshaller.getInstance().marshall(this, protocolMarshaller);
}
}