com.amazonaws.services.guardduty.model.RemoteIpDetails 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.guardduty.model;
import java.io.Serializable;
import javax.annotation.Generated;
import com.amazonaws.protocol.StructuredPojo;
import com.amazonaws.protocol.ProtocolMarshaller;
/**
*
* Contains information about the remote IP address of the connection.
*
*
* @see AWS API
* Documentation
*/
@Generated("com.amazonaws:aws-java-sdk-code-generator")
public class RemoteIpDetails implements Serializable, Cloneable, StructuredPojo {
/**
*
* The city information of the remote IP address.
*
*/
private City city;
/**
*
* The country code of the remote IP address.
*
*/
private Country country;
/**
*
* The location information of the remote IP address.
*
*/
private GeoLocation geoLocation;
/**
*
* The IPv4 remote address of the connection.
*
*/
private String ipAddressV4;
/**
*
* The IPv6 remote address of the connection.
*
*/
private String ipAddressV6;
/**
*
* The ISP organization information of the remote IP address.
*
*/
private Organization organization;
/**
*
* The city information of the remote IP address.
*
*
* @param city
* The city information of the remote IP address.
*/
public void setCity(City city) {
this.city = city;
}
/**
*
* The city information of the remote IP address.
*
*
* @return The city information of the remote IP address.
*/
public City getCity() {
return this.city;
}
/**
*
* The city information of the remote IP address.
*
*
* @param city
* The city information of the remote IP address.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public RemoteIpDetails withCity(City city) {
setCity(city);
return this;
}
/**
*
* The country code of the remote IP address.
*
*
* @param country
* The country code of the remote IP address.
*/
public void setCountry(Country country) {
this.country = country;
}
/**
*
* The country code of the remote IP address.
*
*
* @return The country code of the remote IP address.
*/
public Country getCountry() {
return this.country;
}
/**
*
* The country code of the remote IP address.
*
*
* @param country
* The country code of the remote IP address.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public RemoteIpDetails withCountry(Country country) {
setCountry(country);
return this;
}
/**
*
* The location information of the remote IP address.
*
*
* @param geoLocation
* The location information of the remote IP address.
*/
public void setGeoLocation(GeoLocation geoLocation) {
this.geoLocation = geoLocation;
}
/**
*
* The location information of the remote IP address.
*
*
* @return The location information of the remote IP address.
*/
public GeoLocation getGeoLocation() {
return this.geoLocation;
}
/**
*
* The location information of the remote IP address.
*
*
* @param geoLocation
* The location information of the remote IP address.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public RemoteIpDetails withGeoLocation(GeoLocation geoLocation) {
setGeoLocation(geoLocation);
return this;
}
/**
*
* The IPv4 remote address of the connection.
*
*
* @param ipAddressV4
* The IPv4 remote address of the connection.
*/
public void setIpAddressV4(String ipAddressV4) {
this.ipAddressV4 = ipAddressV4;
}
/**
*
* The IPv4 remote address of the connection.
*
*
* @return The IPv4 remote address of the connection.
*/
public String getIpAddressV4() {
return this.ipAddressV4;
}
/**
*
* The IPv4 remote address of the connection.
*
*
* @param ipAddressV4
* The IPv4 remote address of the connection.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public RemoteIpDetails withIpAddressV4(String ipAddressV4) {
setIpAddressV4(ipAddressV4);
return this;
}
/**
*
* The IPv6 remote address of the connection.
*
*
* @param ipAddressV6
* The IPv6 remote address of the connection.
*/
public void setIpAddressV6(String ipAddressV6) {
this.ipAddressV6 = ipAddressV6;
}
/**
*
* The IPv6 remote address of the connection.
*
*
* @return The IPv6 remote address of the connection.
*/
public String getIpAddressV6() {
return this.ipAddressV6;
}
/**
*
* The IPv6 remote address of the connection.
*
*
* @param ipAddressV6
* The IPv6 remote address of the connection.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public RemoteIpDetails withIpAddressV6(String ipAddressV6) {
setIpAddressV6(ipAddressV6);
return this;
}
/**
*
* The ISP organization information of the remote IP address.
*
*
* @param organization
* The ISP organization information of the remote IP address.
*/
public void setOrganization(Organization organization) {
this.organization = organization;
}
/**
*
* The ISP organization information of the remote IP address.
*
*
* @return The ISP organization information of the remote IP address.
*/
public Organization getOrganization() {
return this.organization;
}
/**
*
* The ISP organization information of the remote IP address.
*
*
* @param organization
* The ISP organization information of the remote IP address.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public RemoteIpDetails withOrganization(Organization organization) {
setOrganization(organization);
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 (getCity() != null)
sb.append("City: ").append(getCity()).append(",");
if (getCountry() != null)
sb.append("Country: ").append(getCountry()).append(",");
if (getGeoLocation() != null)
sb.append("GeoLocation: ").append(getGeoLocation()).append(",");
if (getIpAddressV4() != null)
sb.append("IpAddressV4: ").append("***Sensitive Data Redacted***").append(",");
if (getIpAddressV6() != null)
sb.append("IpAddressV6: ").append("***Sensitive Data Redacted***").append(",");
if (getOrganization() != null)
sb.append("Organization: ").append(getOrganization());
sb.append("}");
return sb.toString();
}
@Override
public boolean equals(Object obj) {
if (this == obj)
return true;
if (obj == null)
return false;
if (obj instanceof RemoteIpDetails == false)
return false;
RemoteIpDetails other = (RemoteIpDetails) obj;
if (other.getCity() == null ^ this.getCity() == null)
return false;
if (other.getCity() != null && other.getCity().equals(this.getCity()) == false)
return false;
if (other.getCountry() == null ^ this.getCountry() == null)
return false;
if (other.getCountry() != null && other.getCountry().equals(this.getCountry()) == false)
return false;
if (other.getGeoLocation() == null ^ this.getGeoLocation() == null)
return false;
if (other.getGeoLocation() != null && other.getGeoLocation().equals(this.getGeoLocation()) == false)
return false;
if (other.getIpAddressV4() == null ^ this.getIpAddressV4() == null)
return false;
if (other.getIpAddressV4() != null && other.getIpAddressV4().equals(this.getIpAddressV4()) == false)
return false;
if (other.getIpAddressV6() == null ^ this.getIpAddressV6() == null)
return false;
if (other.getIpAddressV6() != null && other.getIpAddressV6().equals(this.getIpAddressV6()) == false)
return false;
if (other.getOrganization() == null ^ this.getOrganization() == null)
return false;
if (other.getOrganization() != null && other.getOrganization().equals(this.getOrganization()) == false)
return false;
return true;
}
@Override
public int hashCode() {
final int prime = 31;
int hashCode = 1;
hashCode = prime * hashCode + ((getCity() == null) ? 0 : getCity().hashCode());
hashCode = prime * hashCode + ((getCountry() == null) ? 0 : getCountry().hashCode());
hashCode = prime * hashCode + ((getGeoLocation() == null) ? 0 : getGeoLocation().hashCode());
hashCode = prime * hashCode + ((getIpAddressV4() == null) ? 0 : getIpAddressV4().hashCode());
hashCode = prime * hashCode + ((getIpAddressV6() == null) ? 0 : getIpAddressV6().hashCode());
hashCode = prime * hashCode + ((getOrganization() == null) ? 0 : getOrganization().hashCode());
return hashCode;
}
@Override
public RemoteIpDetails clone() {
try {
return (RemoteIpDetails) 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.RemoteIpDetailsMarshaller.getInstance().marshall(this, protocolMarshaller);
}
}