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

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

/*
 * Copyright 2019-2024 Amazon.com, Inc. or its affiliates. All Rights Reserved.
 * 
 * Licensed under the Apache License, Version 2.0 (the "License"). You may not use this file except in compliance with
 * the License. A copy of the License is located at
 * 
 * http://aws.amazon.com/apache2.0
 * 
 * or in the "license" file accompanying this file. This file is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR
 * CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions
 * and limitations under the License.
 */
package com.amazonaws.services.securityhub.model;

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

/**
 * 

* The inspection criteria for a stateful rule. *

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

* The destination IP address or address range to inspect for, in CIDR notation. To match with any address, specify * ANY. *

*/ private String destination; /** *

* The destination port to inspect for. You can specify an individual port, such as 1994. You also can * specify a port range, such as 1990:1994. To match with any port, specify ANY. *

*/ private String destinationPort; /** *

* The direction of traffic flow to inspect. If set to ANY, the inspection matches bidirectional * traffic, both from the source to the destination and from the destination to the source. If set to * FORWARD, the inspection only matches traffic going from the source to the destination. *

*/ private String direction; /** *

* The protocol to inspect for. To inspector for all protocols, use IP. *

*/ private String protocol; /** *

* The source IP address or address range to inspect for, in CIDR notation. To match with any address, specify * ANY. *

*/ private String source; /** *

* The source port to inspect for. You can specify an individual port, such as 1994. You also can * specify a port range, such as 1990:1994. To match with any port, specify ANY. *

*/ private String sourcePort; /** *

* The destination IP address or address range to inspect for, in CIDR notation. To match with any address, specify * ANY. *

* * @param destination * The destination IP address or address range to inspect for, in CIDR notation. To match with any address, * specify ANY. */ public void setDestination(String destination) { this.destination = destination; } /** *

* The destination IP address or address range to inspect for, in CIDR notation. To match with any address, specify * ANY. *

* * @return The destination IP address or address range to inspect for, in CIDR notation. To match with any address, * specify ANY. */ public String getDestination() { return this.destination; } /** *

* The destination IP address or address range to inspect for, in CIDR notation. To match with any address, specify * ANY. *

* * @param destination * The destination IP address or address range to inspect for, in CIDR notation. To match with any address, * specify ANY. * @return Returns a reference to this object so that method calls can be chained together. */ public RuleGroupSourceStatefulRulesHeaderDetails withDestination(String destination) { setDestination(destination); return this; } /** *

* The destination port to inspect for. You can specify an individual port, such as 1994. You also can * specify a port range, such as 1990:1994. To match with any port, specify ANY. *

* * @param destinationPort * The destination port to inspect for. You can specify an individual port, such as 1994. You * also can specify a port range, such as 1990:1994. To match with any port, specify * ANY. */ public void setDestinationPort(String destinationPort) { this.destinationPort = destinationPort; } /** *

* The destination port to inspect for. You can specify an individual port, such as 1994. You also can * specify a port range, such as 1990:1994. To match with any port, specify ANY. *

* * @return The destination port to inspect for. You can specify an individual port, such as 1994. You * also can specify a port range, such as 1990:1994. To match with any port, specify * ANY. */ public String getDestinationPort() { return this.destinationPort; } /** *

* The destination port to inspect for. You can specify an individual port, such as 1994. You also can * specify a port range, such as 1990:1994. To match with any port, specify ANY. *

* * @param destinationPort * The destination port to inspect for. You can specify an individual port, such as 1994. You * also can specify a port range, such as 1990:1994. To match with any port, specify * ANY. * @return Returns a reference to this object so that method calls can be chained together. */ public RuleGroupSourceStatefulRulesHeaderDetails withDestinationPort(String destinationPort) { setDestinationPort(destinationPort); return this; } /** *

* The direction of traffic flow to inspect. If set to ANY, the inspection matches bidirectional * traffic, both from the source to the destination and from the destination to the source. If set to * FORWARD, the inspection only matches traffic going from the source to the destination. *

* * @param direction * The direction of traffic flow to inspect. If set to ANY, the inspection matches bidirectional * traffic, both from the source to the destination and from the destination to the source. If set to * FORWARD, the inspection only matches traffic going from the source to the destination. */ public void setDirection(String direction) { this.direction = direction; } /** *

* The direction of traffic flow to inspect. If set to ANY, the inspection matches bidirectional * traffic, both from the source to the destination and from the destination to the source. If set to * FORWARD, the inspection only matches traffic going from the source to the destination. *

* * @return The direction of traffic flow to inspect. If set to ANY, the inspection matches * bidirectional traffic, both from the source to the destination and from the destination to the source. If * set to FORWARD, the inspection only matches traffic going from the source to the * destination. */ public String getDirection() { return this.direction; } /** *

* The direction of traffic flow to inspect. If set to ANY, the inspection matches bidirectional * traffic, both from the source to the destination and from the destination to the source. If set to * FORWARD, the inspection only matches traffic going from the source to the destination. *

* * @param direction * The direction of traffic flow to inspect. If set to ANY, the inspection matches bidirectional * traffic, both from the source to the destination and from the destination to the source. If set to * FORWARD, the inspection only matches traffic going from the source to the destination. * @return Returns a reference to this object so that method calls can be chained together. */ public RuleGroupSourceStatefulRulesHeaderDetails withDirection(String direction) { setDirection(direction); return this; } /** *

* The protocol to inspect for. To inspector for all protocols, use IP. *

* * @param protocol * The protocol to inspect for. To inspector for all protocols, use IP. */ public void setProtocol(String protocol) { this.protocol = protocol; } /** *

* The protocol to inspect for. To inspector for all protocols, use IP. *

* * @return The protocol to inspect for. To inspector for all protocols, use IP. */ public String getProtocol() { return this.protocol; } /** *

* The protocol to inspect for. To inspector for all protocols, use IP. *

* * @param protocol * The protocol to inspect for. To inspector for all protocols, use IP. * @return Returns a reference to this object so that method calls can be chained together. */ public RuleGroupSourceStatefulRulesHeaderDetails withProtocol(String protocol) { setProtocol(protocol); return this; } /** *

* The source IP address or address range to inspect for, in CIDR notation. To match with any address, specify * ANY. *

* * @param source * The source IP address or address range to inspect for, in CIDR notation. To match with any address, * specify ANY. */ public void setSource(String source) { this.source = source; } /** *

* The source IP address or address range to inspect for, in CIDR notation. To match with any address, specify * ANY. *

* * @return The source IP address or address range to inspect for, in CIDR notation. To match with any address, * specify ANY. */ public String getSource() { return this.source; } /** *

* The source IP address or address range to inspect for, in CIDR notation. To match with any address, specify * ANY. *

* * @param source * The source IP address or address range to inspect for, in CIDR notation. To match with any address, * specify ANY. * @return Returns a reference to this object so that method calls can be chained together. */ public RuleGroupSourceStatefulRulesHeaderDetails withSource(String source) { setSource(source); return this; } /** *

* The source port to inspect for. You can specify an individual port, such as 1994. You also can * specify a port range, such as 1990:1994. To match with any port, specify ANY. *

* * @param sourcePort * The source port to inspect for. You can specify an individual port, such as 1994. You also * can specify a port range, such as 1990:1994. To match with any port, specify ANY * . */ public void setSourcePort(String sourcePort) { this.sourcePort = sourcePort; } /** *

* The source port to inspect for. You can specify an individual port, such as 1994. You also can * specify a port range, such as 1990:1994. To match with any port, specify ANY. *

* * @return The source port to inspect for. You can specify an individual port, such as 1994. You also * can specify a port range, such as 1990:1994. To match with any port, specify * ANY. */ public String getSourcePort() { return this.sourcePort; } /** *

* The source port to inspect for. You can specify an individual port, such as 1994. You also can * specify a port range, such as 1990:1994. To match with any port, specify ANY. *

* * @param sourcePort * The source port to inspect for. You can specify an individual port, such as 1994. You also * can specify a port range, such as 1990:1994. To match with any port, specify ANY * . * @return Returns a reference to this object so that method calls can be chained together. */ public RuleGroupSourceStatefulRulesHeaderDetails withSourcePort(String sourcePort) { setSourcePort(sourcePort); 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 (getDestination() != null) sb.append("Destination: ").append(getDestination()).append(","); if (getDestinationPort() != null) sb.append("DestinationPort: ").append(getDestinationPort()).append(","); if (getDirection() != null) sb.append("Direction: ").append(getDirection()).append(","); if (getProtocol() != null) sb.append("Protocol: ").append(getProtocol()).append(","); if (getSource() != null) sb.append("Source: ").append(getSource()).append(","); if (getSourcePort() != null) sb.append("SourcePort: ").append(getSourcePort()); sb.append("}"); return sb.toString(); } @Override public boolean equals(Object obj) { if (this == obj) return true; if (obj == null) return false; if (obj instanceof RuleGroupSourceStatefulRulesHeaderDetails == false) return false; RuleGroupSourceStatefulRulesHeaderDetails other = (RuleGroupSourceStatefulRulesHeaderDetails) obj; if (other.getDestination() == null ^ this.getDestination() == null) return false; if (other.getDestination() != null && other.getDestination().equals(this.getDestination()) == false) return false; if (other.getDestinationPort() == null ^ this.getDestinationPort() == null) return false; if (other.getDestinationPort() != null && other.getDestinationPort().equals(this.getDestinationPort()) == false) return false; if (other.getDirection() == null ^ this.getDirection() == null) return false; if (other.getDirection() != null && other.getDirection().equals(this.getDirection()) == 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.getSource() == null ^ this.getSource() == null) return false; if (other.getSource() != null && other.getSource().equals(this.getSource()) == false) return false; if (other.getSourcePort() == null ^ this.getSourcePort() == null) return false; if (other.getSourcePort() != null && other.getSourcePort().equals(this.getSourcePort()) == false) return false; return true; } @Override public int hashCode() { final int prime = 31; int hashCode = 1; hashCode = prime * hashCode + ((getDestination() == null) ? 0 : getDestination().hashCode()); hashCode = prime * hashCode + ((getDestinationPort() == null) ? 0 : getDestinationPort().hashCode()); hashCode = prime * hashCode + ((getDirection() == null) ? 0 : getDirection().hashCode()); hashCode = prime * hashCode + ((getProtocol() == null) ? 0 : getProtocol().hashCode()); hashCode = prime * hashCode + ((getSource() == null) ? 0 : getSource().hashCode()); hashCode = prime * hashCode + ((getSourcePort() == null) ? 0 : getSourcePort().hashCode()); return hashCode; } @Override public RuleGroupSourceStatefulRulesHeaderDetails clone() { try { return (RuleGroupSourceStatefulRulesHeaderDetails) 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.RuleGroupSourceStatefulRulesHeaderDetailsMarshaller.getInstance().marshall(this, protocolMarshaller); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy