/* * 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.guardduty.model; import java.io.Serializable; import javax.annotation.Generated; import com.amazonaws.protocol.StructuredPojo; import com.amazonaws.protocol.ProtocolMarshaller; /** *
* Contains information about the DNS_REQUEST action described in this finding. *
* * @see AWS API * Documentation */ @Generated("com.amazonaws:aws-java-sdk-code-generator") public class DnsRequestAction implements Serializable, Cloneable, StructuredPojo { /** ** The domain information for the DNS query. *
*/ private String domain; /** ** The network connection protocol observed in the activity that prompted GuardDuty to generate the finding. *
*/ private String protocol; /** ** Indicates whether the targeted port is blocked. *
*/ private Boolean blocked; /** ** The domain information for the DNS query. *
* * @param domain * The domain information for the DNS query. */ public void setDomain(String domain) { this.domain = domain; } /** ** The domain information for the DNS query. *
* * @return The domain information for the DNS query. */ public String getDomain() { return this.domain; } /** ** The domain information for the DNS query. *
* * @param domain * The domain information for the DNS query. * @return Returns a reference to this object so that method calls can be chained together. */ public DnsRequestAction withDomain(String domain) { setDomain(domain); return this; } /** ** The network connection protocol observed in the activity that prompted GuardDuty to generate the finding. *
* * @param protocol * The network connection protocol observed in the activity that prompted GuardDuty to generate the finding. */ public void setProtocol(String protocol) { this.protocol = protocol; } /** ** The network connection protocol observed in the activity that prompted GuardDuty to generate the finding. *
* * @return The network connection protocol observed in the activity that prompted GuardDuty to generate the finding. */ public String getProtocol() { return this.protocol; } /** ** The network connection protocol observed in the activity that prompted GuardDuty to generate the finding. *
* * @param protocol * The network connection protocol observed in the activity that prompted GuardDuty to generate the finding. * @return Returns a reference to this object so that method calls can be chained together. */ public DnsRequestAction withProtocol(String protocol) { setProtocol(protocol); return this; } /** ** Indicates whether the targeted port is blocked. *
* * @param blocked * Indicates whether the targeted port is blocked. */ public void setBlocked(Boolean blocked) { this.blocked = blocked; } /** ** Indicates whether the targeted port is blocked. *
* * @return Indicates whether the targeted port is blocked. */ public Boolean getBlocked() { return this.blocked; } /** ** Indicates whether the targeted port is blocked. *
* * @param blocked * Indicates whether the targeted port is blocked. * @return Returns a reference to this object so that method calls can be chained together. */ public DnsRequestAction withBlocked(Boolean blocked) { setBlocked(blocked); return this; } /** ** Indicates whether the targeted port is blocked. *
* * @return Indicates whether the targeted port is blocked. */ public Boolean isBlocked() { return this.blocked; } /** * 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 (getDomain() != null) sb.append("Domain: ").append(getDomain()).append(","); if (getProtocol() != null) sb.append("Protocol: ").append(getProtocol()).append(","); if (getBlocked() != null) sb.append("Blocked: ").append(getBlocked()); sb.append("}"); return sb.toString(); } @Override public boolean equals(Object obj) { if (this == obj) return true; if (obj == null) return false; if (obj instanceof DnsRequestAction == false) return false; DnsRequestAction other = (DnsRequestAction) obj; if (other.getDomain() == null ^ this.getDomain() == null) return false; if (other.getDomain() != null && other.getDomain().equals(this.getDomain()) == false) return false; if (other.getProtocol() == null ^ this.getProtocol() == null) return false; if (other.getProtocol() != null && other.getProtocol().equals(this.getProtocol()) == false) return false; if (other.getBlocked() == null ^ this.getBlocked() == null) return false; if (other.getBlocked() != null && other.getBlocked().equals(this.getBlocked()) == false) return false; return true; } @Override public int hashCode() { final int prime = 31; int hashCode = 1; hashCode = prime * hashCode + ((getDomain() == null) ? 0 : getDomain().hashCode()); hashCode = prime * hashCode + ((getProtocol() == null) ? 0 : getProtocol().hashCode()); hashCode = prime * hashCode + ((getBlocked() == null) ? 0 : getBlocked().hashCode()); return hashCode; } @Override public DnsRequestAction clone() { try { return (DnsRequestAction) 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.DnsRequestActionMarshaller.getInstance().marshall(this, protocolMarshaller); } }