com.amazonaws.services.cloudfront.model.Origin 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.cloudfront.model;
import java.io.Serializable;
import javax.annotation.Generated;
/**
*
* An origin.
*
*
* An origin is the location where content is stored, and from which CloudFront gets content to serve to viewers. To
* specify an origin:
*
*
* -
*
* Use S3OriginConfig
to specify an Amazon S3 bucket that is not configured with static website hosting.
*
*
* -
*
* Use CustomOriginConfig
to specify all other kinds of origins, including:
*
*
* -
*
* An Amazon S3 bucket that is configured with static website hosting
*
*
* -
*
* An Elastic Load Balancing load balancer
*
*
* -
*
* An Elemental MediaPackage endpoint
*
*
* -
*
* An Elemental MediaStore container
*
*
* -
*
* Any other HTTP server, running on an Amazon EC2 instance or any other kind of host
*
*
*
*
*
*
* For the current maximum number of origins that you can specify per distribution, see General Quotas on Web Distributions in the Amazon CloudFront Developer Guide (quotas were formerly
* referred to as limits).
*
*
* @see AWS API
* Documentation
*/
@Generated("com.amazonaws:aws-java-sdk-code-generator")
public class Origin implements Serializable, Cloneable {
/**
*
* A unique identifier for the origin. This value must be unique within the distribution.
*
*
* Use this value to specify the TargetOriginId
in a CacheBehavior
or
* DefaultCacheBehavior
.
*
*/
private String id;
/**
*
* The domain name for the origin.
*
*
* For more information, see Origin Domain Name in the Amazon CloudFront Developer Guide.
*
*/
private String domainName;
/**
*
* An optional path that CloudFront appends to the origin domain name when CloudFront requests content from the
* origin.
*
*
* For more information, see Origin Path in the Amazon CloudFront Developer Guide.
*
*/
private String originPath;
/**
*
* A list of HTTP header names and values that CloudFront adds to the requests that it sends to the origin.
*
*
* For more information, see Adding
* Custom Headers to Origin Requests in the Amazon CloudFront Developer Guide.
*
*/
private CustomHeaders customHeaders;
/**
*
* Use this type to specify an origin that is an Amazon S3 bucket that is not configured with static website
* hosting. To specify any other type of origin, including an Amazon S3 bucket that is configured with static
* website hosting, use the CustomOriginConfig
type instead.
*
*/
private S3OriginConfig s3OriginConfig;
/**
*
* Use this type to specify an origin that is not an Amazon S3 bucket, with one exception. If the Amazon S3 bucket
* is configured with static website hosting, use this type. If the Amazon S3 bucket is not configured with static
* website hosting, use the S3OriginConfig
type instead.
*
*/
private CustomOriginConfig customOriginConfig;
/**
*
* The number of times that CloudFront attempts to connect to the origin. The minimum number is 1, the maximum is 3,
* and the default (if you don't specify otherwise) is 3.
*
*
* For a custom origin (including an Amazon S3 bucket that's configured with static website hosting), this value
* also specifies the number of times that CloudFront attempts to get a response from the origin, in the case of an
* Origin Response Timeout.
*
*
* For more information, see Origin Connection Attempts in the Amazon CloudFront Developer Guide.
*
*/
private Integer connectionAttempts;
/**
*
* The number of seconds that CloudFront waits when trying to establish a connection to the origin. The minimum
* timeout is 1 second, the maximum is 10 seconds, and the default (if you don't specify otherwise) is 10 seconds.
*
*
* For more information, see Origin Connection Timeout in the Amazon CloudFront Developer Guide.
*
*/
private Integer connectionTimeout;
/**
*
* CloudFront Origin Shield. Using Origin Shield can help reduce the load on your origin.
*
*
* For more information, see Using Origin
* Shield in the Amazon CloudFront Developer Guide.
*
*/
private OriginShield originShield;
/**
*
* The unique identifier of an origin access control for this origin.
*
*
* For more information, see Restricting access to an Amazon S3 origin in the Amazon CloudFront Developer Guide.
*
*/
private String originAccessControlId;
/**
*
* A unique identifier for the origin. This value must be unique within the distribution.
*
*
* Use this value to specify the TargetOriginId
in a CacheBehavior
or
* DefaultCacheBehavior
.
*
*
* @param id
* A unique identifier for the origin. This value must be unique within the distribution.
*
* Use this value to specify the TargetOriginId
in a CacheBehavior
or
* DefaultCacheBehavior
.
*/
public void setId(String id) {
this.id = id;
}
/**
*
* A unique identifier for the origin. This value must be unique within the distribution.
*
*
* Use this value to specify the TargetOriginId
in a CacheBehavior
or
* DefaultCacheBehavior
.
*
*
* @return A unique identifier for the origin. This value must be unique within the distribution.
*
* Use this value to specify the TargetOriginId
in a CacheBehavior
or
* DefaultCacheBehavior
.
*/
public String getId() {
return this.id;
}
/**
*
* A unique identifier for the origin. This value must be unique within the distribution.
*
*
* Use this value to specify the TargetOriginId
in a CacheBehavior
or
* DefaultCacheBehavior
.
*
*
* @param id
* A unique identifier for the origin. This value must be unique within the distribution.
*
* Use this value to specify the TargetOriginId
in a CacheBehavior
or
* DefaultCacheBehavior
.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public Origin withId(String id) {
setId(id);
return this;
}
/**
*
* The domain name for the origin.
*
*
* For more information, see Origin Domain Name in the Amazon CloudFront Developer Guide.
*
*
* @param domainName
* The domain name for the origin.
*
* For more information, see Origin Domain Name in the Amazon CloudFront Developer Guide.
*/
public void setDomainName(String domainName) {
this.domainName = domainName;
}
/**
*
* The domain name for the origin.
*
*
* For more information, see Origin Domain Name in the Amazon CloudFront Developer Guide.
*
*
* @return The domain name for the origin.
*
* For more information, see Origin Domain Name in the Amazon CloudFront Developer Guide.
*/
public String getDomainName() {
return this.domainName;
}
/**
*
* The domain name for the origin.
*
*
* For more information, see Origin Domain Name in the Amazon CloudFront Developer Guide.
*
*
* @param domainName
* The domain name for the origin.
*
* For more information, see Origin Domain Name in the Amazon CloudFront Developer Guide.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public Origin withDomainName(String domainName) {
setDomainName(domainName);
return this;
}
/**
*
* An optional path that CloudFront appends to the origin domain name when CloudFront requests content from the
* origin.
*
*
* For more information, see Origin Path in the Amazon CloudFront Developer Guide.
*
*
* @param originPath
* An optional path that CloudFront appends to the origin domain name when CloudFront requests content from
* the origin.
*
* For more information, see Origin Path in the Amazon CloudFront Developer Guide.
*/
public void setOriginPath(String originPath) {
this.originPath = originPath;
}
/**
*
* An optional path that CloudFront appends to the origin domain name when CloudFront requests content from the
* origin.
*
*
* For more information, see Origin Path in the Amazon CloudFront Developer Guide.
*
*
* @return An optional path that CloudFront appends to the origin domain name when CloudFront requests content from
* the origin.
*
* For more information, see Origin Path in the Amazon CloudFront Developer Guide.
*/
public String getOriginPath() {
return this.originPath;
}
/**
*
* An optional path that CloudFront appends to the origin domain name when CloudFront requests content from the
* origin.
*
*
* For more information, see Origin Path in the Amazon CloudFront Developer Guide.
*
*
* @param originPath
* An optional path that CloudFront appends to the origin domain name when CloudFront requests content from
* the origin.
*
* For more information, see Origin Path in the Amazon CloudFront Developer Guide.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public Origin withOriginPath(String originPath) {
setOriginPath(originPath);
return this;
}
/**
*
* A list of HTTP header names and values that CloudFront adds to the requests that it sends to the origin.
*
*
* For more information, see Adding
* Custom Headers to Origin Requests in the Amazon CloudFront Developer Guide.
*
*
* @param customHeaders
* A list of HTTP header names and values that CloudFront adds to the requests that it sends to the
* origin.
*
* For more information, see Adding Custom Headers to Origin Requests in the Amazon CloudFront Developer Guide.
*/
public void setCustomHeaders(CustomHeaders customHeaders) {
this.customHeaders = customHeaders;
}
/**
*
* A list of HTTP header names and values that CloudFront adds to the requests that it sends to the origin.
*
*
* For more information, see Adding
* Custom Headers to Origin Requests in the Amazon CloudFront Developer Guide.
*
*
* @return A list of HTTP header names and values that CloudFront adds to the requests that it sends to the
* origin.
*
* For more information, see Adding Custom Headers to Origin Requests in the Amazon CloudFront Developer Guide.
*/
public CustomHeaders getCustomHeaders() {
return this.customHeaders;
}
/**
*
* A list of HTTP header names and values that CloudFront adds to the requests that it sends to the origin.
*
*
* For more information, see Adding
* Custom Headers to Origin Requests in the Amazon CloudFront Developer Guide.
*
*
* @param customHeaders
* A list of HTTP header names and values that CloudFront adds to the requests that it sends to the
* origin.
*
* For more information, see Adding Custom Headers to Origin Requests in the Amazon CloudFront Developer Guide.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public Origin withCustomHeaders(CustomHeaders customHeaders) {
setCustomHeaders(customHeaders);
return this;
}
/**
*
* Use this type to specify an origin that is an Amazon S3 bucket that is not configured with static website
* hosting. To specify any other type of origin, including an Amazon S3 bucket that is configured with static
* website hosting, use the CustomOriginConfig
type instead.
*
*
* @param s3OriginConfig
* Use this type to specify an origin that is an Amazon S3 bucket that is not configured with static website
* hosting. To specify any other type of origin, including an Amazon S3 bucket that is configured with static
* website hosting, use the CustomOriginConfig
type instead.
*/
public void setS3OriginConfig(S3OriginConfig s3OriginConfig) {
this.s3OriginConfig = s3OriginConfig;
}
/**
*
* Use this type to specify an origin that is an Amazon S3 bucket that is not configured with static website
* hosting. To specify any other type of origin, including an Amazon S3 bucket that is configured with static
* website hosting, use the CustomOriginConfig
type instead.
*
*
* @return Use this type to specify an origin that is an Amazon S3 bucket that is not configured with static website
* hosting. To specify any other type of origin, including an Amazon S3 bucket that is configured with
* static website hosting, use the CustomOriginConfig
type instead.
*/
public S3OriginConfig getS3OriginConfig() {
return this.s3OriginConfig;
}
/**
*
* Use this type to specify an origin that is an Amazon S3 bucket that is not configured with static website
* hosting. To specify any other type of origin, including an Amazon S3 bucket that is configured with static
* website hosting, use the CustomOriginConfig
type instead.
*
*
* @param s3OriginConfig
* Use this type to specify an origin that is an Amazon S3 bucket that is not configured with static website
* hosting. To specify any other type of origin, including an Amazon S3 bucket that is configured with static
* website hosting, use the CustomOriginConfig
type instead.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public Origin withS3OriginConfig(S3OriginConfig s3OriginConfig) {
setS3OriginConfig(s3OriginConfig);
return this;
}
/**
*
* Use this type to specify an origin that is not an Amazon S3 bucket, with one exception. If the Amazon S3 bucket
* is configured with static website hosting, use this type. If the Amazon S3 bucket is not configured with static
* website hosting, use the S3OriginConfig
type instead.
*
*
* @param customOriginConfig
* Use this type to specify an origin that is not an Amazon S3 bucket, with one exception. If the Amazon S3
* bucket is configured with static website hosting, use this type. If the Amazon S3 bucket is not configured
* with static website hosting, use the S3OriginConfig
type instead.
*/
public void setCustomOriginConfig(CustomOriginConfig customOriginConfig) {
this.customOriginConfig = customOriginConfig;
}
/**
*
* Use this type to specify an origin that is not an Amazon S3 bucket, with one exception. If the Amazon S3 bucket
* is configured with static website hosting, use this type. If the Amazon S3 bucket is not configured with static
* website hosting, use the S3OriginConfig
type instead.
*
*
* @return Use this type to specify an origin that is not an Amazon S3 bucket, with one exception. If the Amazon S3
* bucket is configured with static website hosting, use this type. If the Amazon S3 bucket is not
* configured with static website hosting, use the S3OriginConfig
type instead.
*/
public CustomOriginConfig getCustomOriginConfig() {
return this.customOriginConfig;
}
/**
*
* Use this type to specify an origin that is not an Amazon S3 bucket, with one exception. If the Amazon S3 bucket
* is configured with static website hosting, use this type. If the Amazon S3 bucket is not configured with static
* website hosting, use the S3OriginConfig
type instead.
*
*
* @param customOriginConfig
* Use this type to specify an origin that is not an Amazon S3 bucket, with one exception. If the Amazon S3
* bucket is configured with static website hosting, use this type. If the Amazon S3 bucket is not configured
* with static website hosting, use the S3OriginConfig
type instead.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public Origin withCustomOriginConfig(CustomOriginConfig customOriginConfig) {
setCustomOriginConfig(customOriginConfig);
return this;
}
/**
*
* The number of times that CloudFront attempts to connect to the origin. The minimum number is 1, the maximum is 3,
* and the default (if you don't specify otherwise) is 3.
*
*
* For a custom origin (including an Amazon S3 bucket that's configured with static website hosting), this value
* also specifies the number of times that CloudFront attempts to get a response from the origin, in the case of an
* Origin Response Timeout.
*
*
* For more information, see Origin Connection Attempts in the Amazon CloudFront Developer Guide.
*
*
* @param connectionAttempts
* The number of times that CloudFront attempts to connect to the origin. The minimum number is 1, the
* maximum is 3, and the default (if you don't specify otherwise) is 3.
*
* For a custom origin (including an Amazon S3 bucket that's configured with static website hosting), this
* value also specifies the number of times that CloudFront attempts to get a response from the origin, in
* the case of an Origin Response Timeout.
*
*
* For more information, see Origin Connection Attempts in the Amazon CloudFront Developer Guide.
*/
public void setConnectionAttempts(Integer connectionAttempts) {
this.connectionAttempts = connectionAttempts;
}
/**
*
* The number of times that CloudFront attempts to connect to the origin. The minimum number is 1, the maximum is 3,
* and the default (if you don't specify otherwise) is 3.
*
*
* For a custom origin (including an Amazon S3 bucket that's configured with static website hosting), this value
* also specifies the number of times that CloudFront attempts to get a response from the origin, in the case of an
* Origin Response Timeout.
*
*
* For more information, see Origin Connection Attempts in the Amazon CloudFront Developer Guide.
*
*
* @return The number of times that CloudFront attempts to connect to the origin. The minimum number is 1, the
* maximum is 3, and the default (if you don't specify otherwise) is 3.
*
* For a custom origin (including an Amazon S3 bucket that's configured with static website hosting), this
* value also specifies the number of times that CloudFront attempts to get a response from the origin, in
* the case of an Origin Response Timeout.
*
*
* For more information, see Origin Connection Attempts in the Amazon CloudFront Developer Guide.
*/
public Integer getConnectionAttempts() {
return this.connectionAttempts;
}
/**
*
* The number of times that CloudFront attempts to connect to the origin. The minimum number is 1, the maximum is 3,
* and the default (if you don't specify otherwise) is 3.
*
*
* For a custom origin (including an Amazon S3 bucket that's configured with static website hosting), this value
* also specifies the number of times that CloudFront attempts to get a response from the origin, in the case of an
* Origin Response Timeout.
*
*
* For more information, see Origin Connection Attempts in the Amazon CloudFront Developer Guide.
*
*
* @param connectionAttempts
* The number of times that CloudFront attempts to connect to the origin. The minimum number is 1, the
* maximum is 3, and the default (if you don't specify otherwise) is 3.
*
* For a custom origin (including an Amazon S3 bucket that's configured with static website hosting), this
* value also specifies the number of times that CloudFront attempts to get a response from the origin, in
* the case of an Origin Response Timeout.
*
*
* For more information, see Origin Connection Attempts in the Amazon CloudFront Developer Guide.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public Origin withConnectionAttempts(Integer connectionAttempts) {
setConnectionAttempts(connectionAttempts);
return this;
}
/**
*
* The number of seconds that CloudFront waits when trying to establish a connection to the origin. The minimum
* timeout is 1 second, the maximum is 10 seconds, and the default (if you don't specify otherwise) is 10 seconds.
*
*
* For more information, see Origin Connection Timeout in the Amazon CloudFront Developer Guide.
*
*
* @param connectionTimeout
* The number of seconds that CloudFront waits when trying to establish a connection to the origin. The
* minimum timeout is 1 second, the maximum is 10 seconds, and the default (if you don't specify otherwise)
* is 10 seconds.
*
* For more information, see Origin Connection Timeout in the Amazon CloudFront Developer Guide.
*/
public void setConnectionTimeout(Integer connectionTimeout) {
this.connectionTimeout = connectionTimeout;
}
/**
*
* The number of seconds that CloudFront waits when trying to establish a connection to the origin. The minimum
* timeout is 1 second, the maximum is 10 seconds, and the default (if you don't specify otherwise) is 10 seconds.
*
*
* For more information, see Origin Connection Timeout in the Amazon CloudFront Developer Guide.
*
*
* @return The number of seconds that CloudFront waits when trying to establish a connection to the origin. The
* minimum timeout is 1 second, the maximum is 10 seconds, and the default (if you don't specify otherwise)
* is 10 seconds.
*
* For more information, see Origin Connection Timeout in the Amazon CloudFront Developer Guide.
*/
public Integer getConnectionTimeout() {
return this.connectionTimeout;
}
/**
*
* The number of seconds that CloudFront waits when trying to establish a connection to the origin. The minimum
* timeout is 1 second, the maximum is 10 seconds, and the default (if you don't specify otherwise) is 10 seconds.
*
*
* For more information, see Origin Connection Timeout in the Amazon CloudFront Developer Guide.
*
*
* @param connectionTimeout
* The number of seconds that CloudFront waits when trying to establish a connection to the origin. The
* minimum timeout is 1 second, the maximum is 10 seconds, and the default (if you don't specify otherwise)
* is 10 seconds.
*
* For more information, see Origin Connection Timeout in the Amazon CloudFront Developer Guide.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public Origin withConnectionTimeout(Integer connectionTimeout) {
setConnectionTimeout(connectionTimeout);
return this;
}
/**
*
* CloudFront Origin Shield. Using Origin Shield can help reduce the load on your origin.
*
*
* For more information, see Using Origin
* Shield in the Amazon CloudFront Developer Guide.
*
*
* @param originShield
* CloudFront Origin Shield. Using Origin Shield can help reduce the load on your origin.
*
* For more information, see Using Origin
* Shield in the Amazon CloudFront Developer Guide.
*/
public void setOriginShield(OriginShield originShield) {
this.originShield = originShield;
}
/**
*
* CloudFront Origin Shield. Using Origin Shield can help reduce the load on your origin.
*
*
* For more information, see Using Origin
* Shield in the Amazon CloudFront Developer Guide.
*
*
* @return CloudFront Origin Shield. Using Origin Shield can help reduce the load on your origin.
*
* For more information, see Using Origin
* Shield in the Amazon CloudFront Developer Guide.
*/
public OriginShield getOriginShield() {
return this.originShield;
}
/**
*
* CloudFront Origin Shield. Using Origin Shield can help reduce the load on your origin.
*
*
* For more information, see Using Origin
* Shield in the Amazon CloudFront Developer Guide.
*
*
* @param originShield
* CloudFront Origin Shield. Using Origin Shield can help reduce the load on your origin.
*
* For more information, see Using Origin
* Shield in the Amazon CloudFront Developer Guide.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public Origin withOriginShield(OriginShield originShield) {
setOriginShield(originShield);
return this;
}
/**
*
* The unique identifier of an origin access control for this origin.
*
*
* For more information, see Restricting access to an Amazon S3 origin in the Amazon CloudFront Developer Guide.
*
*
* @param originAccessControlId
* The unique identifier of an origin access control for this origin.
*
* For more information, see Restricting access to an Amazon S3 origin in the Amazon CloudFront Developer Guide.
*/
public void setOriginAccessControlId(String originAccessControlId) {
this.originAccessControlId = originAccessControlId;
}
/**
*
* The unique identifier of an origin access control for this origin.
*
*
* For more information, see Restricting access to an Amazon S3 origin in the Amazon CloudFront Developer Guide.
*
*
* @return The unique identifier of an origin access control for this origin.
*
* For more information, see Restricting access to an Amazon S3 origin in the Amazon CloudFront Developer Guide.
*/
public String getOriginAccessControlId() {
return this.originAccessControlId;
}
/**
*
* The unique identifier of an origin access control for this origin.
*
*
* For more information, see Restricting access to an Amazon S3 origin in the Amazon CloudFront Developer Guide.
*
*
* @param originAccessControlId
* The unique identifier of an origin access control for this origin.
*
* For more information, see Restricting access to an Amazon S3 origin in the Amazon CloudFront Developer Guide.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public Origin withOriginAccessControlId(String originAccessControlId) {
setOriginAccessControlId(originAccessControlId);
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 (getId() != null)
sb.append("Id: ").append(getId()).append(",");
if (getDomainName() != null)
sb.append("DomainName: ").append(getDomainName()).append(",");
if (getOriginPath() != null)
sb.append("OriginPath: ").append(getOriginPath()).append(",");
if (getCustomHeaders() != null)
sb.append("CustomHeaders: ").append(getCustomHeaders()).append(",");
if (getS3OriginConfig() != null)
sb.append("S3OriginConfig: ").append(getS3OriginConfig()).append(",");
if (getCustomOriginConfig() != null)
sb.append("CustomOriginConfig: ").append(getCustomOriginConfig()).append(",");
if (getConnectionAttempts() != null)
sb.append("ConnectionAttempts: ").append(getConnectionAttempts()).append(",");
if (getConnectionTimeout() != null)
sb.append("ConnectionTimeout: ").append(getConnectionTimeout()).append(",");
if (getOriginShield() != null)
sb.append("OriginShield: ").append(getOriginShield()).append(",");
if (getOriginAccessControlId() != null)
sb.append("OriginAccessControlId: ").append(getOriginAccessControlId());
sb.append("}");
return sb.toString();
}
@Override
public boolean equals(Object obj) {
if (this == obj)
return true;
if (obj == null)
return false;
if (obj instanceof Origin == false)
return false;
Origin other = (Origin) obj;
if (other.getId() == null ^ this.getId() == null)
return false;
if (other.getId() != null && other.getId().equals(this.getId()) == false)
return false;
if (other.getDomainName() == null ^ this.getDomainName() == null)
return false;
if (other.getDomainName() != null && other.getDomainName().equals(this.getDomainName()) == false)
return false;
if (other.getOriginPath() == null ^ this.getOriginPath() == null)
return false;
if (other.getOriginPath() != null && other.getOriginPath().equals(this.getOriginPath()) == false)
return false;
if (other.getCustomHeaders() == null ^ this.getCustomHeaders() == null)
return false;
if (other.getCustomHeaders() != null && other.getCustomHeaders().equals(this.getCustomHeaders()) == false)
return false;
if (other.getS3OriginConfig() == null ^ this.getS3OriginConfig() == null)
return false;
if (other.getS3OriginConfig() != null && other.getS3OriginConfig().equals(this.getS3OriginConfig()) == false)
return false;
if (other.getCustomOriginConfig() == null ^ this.getCustomOriginConfig() == null)
return false;
if (other.getCustomOriginConfig() != null && other.getCustomOriginConfig().equals(this.getCustomOriginConfig()) == false)
return false;
if (other.getConnectionAttempts() == null ^ this.getConnectionAttempts() == null)
return false;
if (other.getConnectionAttempts() != null && other.getConnectionAttempts().equals(this.getConnectionAttempts()) == false)
return false;
if (other.getConnectionTimeout() == null ^ this.getConnectionTimeout() == null)
return false;
if (other.getConnectionTimeout() != null && other.getConnectionTimeout().equals(this.getConnectionTimeout()) == false)
return false;
if (other.getOriginShield() == null ^ this.getOriginShield() == null)
return false;
if (other.getOriginShield() != null && other.getOriginShield().equals(this.getOriginShield()) == false)
return false;
if (other.getOriginAccessControlId() == null ^ this.getOriginAccessControlId() == null)
return false;
if (other.getOriginAccessControlId() != null && other.getOriginAccessControlId().equals(this.getOriginAccessControlId()) == false)
return false;
return true;
}
@Override
public int hashCode() {
final int prime = 31;
int hashCode = 1;
hashCode = prime * hashCode + ((getId() == null) ? 0 : getId().hashCode());
hashCode = prime * hashCode + ((getDomainName() == null) ? 0 : getDomainName().hashCode());
hashCode = prime * hashCode + ((getOriginPath() == null) ? 0 : getOriginPath().hashCode());
hashCode = prime * hashCode + ((getCustomHeaders() == null) ? 0 : getCustomHeaders().hashCode());
hashCode = prime * hashCode + ((getS3OriginConfig() == null) ? 0 : getS3OriginConfig().hashCode());
hashCode = prime * hashCode + ((getCustomOriginConfig() == null) ? 0 : getCustomOriginConfig().hashCode());
hashCode = prime * hashCode + ((getConnectionAttempts() == null) ? 0 : getConnectionAttempts().hashCode());
hashCode = prime * hashCode + ((getConnectionTimeout() == null) ? 0 : getConnectionTimeout().hashCode());
hashCode = prime * hashCode + ((getOriginShield() == null) ? 0 : getOriginShield().hashCode());
hashCode = prime * hashCode + ((getOriginAccessControlId() == null) ? 0 : getOriginAccessControlId().hashCode());
return hashCode;
}
@Override
public Origin clone() {
try {
return (Origin) super.clone();
} catch (CloneNotSupportedException e) {
throw new IllegalStateException("Got a CloneNotSupportedException from Object.clone() " + "even though we're Cloneable!", e);
}
}
}