com.amazonaws.services.securityhub.model.AwsCloudFrontDistributionViewerCertificate Maven / Gradle / Ivy
/*
* 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.securityhub.model;
import java.io.Serializable;
import javax.annotation.Generated;
import com.amazonaws.protocol.StructuredPojo;
import com.amazonaws.protocol.ProtocolMarshaller;
/**
*
* Provides information about the TLS/SSL configuration that the CloudFront distribution uses to communicate with
* viewers.
*
*
* @see AWS API Documentation
*/
@Generated("com.amazonaws:aws-java-sdk-code-generator")
public class AwsCloudFrontDistributionViewerCertificate implements Serializable, Cloneable, StructuredPojo {
/**
*
* The ARN of the ACM certificate. Used if the certificate is stored in ACM. If you provide an ACM certificate ARN,
* you must also provide MinimumCertificateVersion
and SslSupportMethod
.
*
*/
private String acmCertificateArn;
/**
*
* The identifier of the certificate. Note that in CloudFront, this attribute is deprecated.
*
*/
private String certificate;
/**
*
* The source of the certificate identified by Certificate
. Note that in CloudFront, this attribute is
* deprecated.
*
*/
private String certificateSource;
/**
*
* Whether the distribution uses the CloudFront domain name. If set to false
, then you provide either
* AcmCertificateArn
or IamCertificateId
.
*
*/
private Boolean cloudFrontDefaultCertificate;
/**
*
* The identifier of the IAM certificate. Used if the certificate is stored in IAM. If you provide
* IamCertificateId
, then you also must provide MinimumProtocolVersion
and
* SslSupportMethod
.
*
*/
private String iamCertificateId;
/**
*
* The security policy that CloudFront uses for HTTPS connections with viewers. If SslSupportMethod
is
* sni-only
, then MinimumProtocolVersion
must be TLSv1
or higher.
*
*/
private String minimumProtocolVersion;
/**
*
* The viewers that the distribution accepts HTTPS connections from.
*
*/
private String sslSupportMethod;
/**
*
* The ARN of the ACM certificate. Used if the certificate is stored in ACM. If you provide an ACM certificate ARN,
* you must also provide MinimumCertificateVersion
and SslSupportMethod
.
*
*
* @param acmCertificateArn
* The ARN of the ACM certificate. Used if the certificate is stored in ACM. If you provide an ACM
* certificate ARN, you must also provide MinimumCertificateVersion
and
* SslSupportMethod
.
*/
public void setAcmCertificateArn(String acmCertificateArn) {
this.acmCertificateArn = acmCertificateArn;
}
/**
*
* The ARN of the ACM certificate. Used if the certificate is stored in ACM. If you provide an ACM certificate ARN,
* you must also provide MinimumCertificateVersion
and SslSupportMethod
.
*
*
* @return The ARN of the ACM certificate. Used if the certificate is stored in ACM. If you provide an ACM
* certificate ARN, you must also provide MinimumCertificateVersion
and
* SslSupportMethod
.
*/
public String getAcmCertificateArn() {
return this.acmCertificateArn;
}
/**
*
* The ARN of the ACM certificate. Used if the certificate is stored in ACM. If you provide an ACM certificate ARN,
* you must also provide MinimumCertificateVersion
and SslSupportMethod
.
*
*
* @param acmCertificateArn
* The ARN of the ACM certificate. Used if the certificate is stored in ACM. If you provide an ACM
* certificate ARN, you must also provide MinimumCertificateVersion
and
* SslSupportMethod
.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public AwsCloudFrontDistributionViewerCertificate withAcmCertificateArn(String acmCertificateArn) {
setAcmCertificateArn(acmCertificateArn);
return this;
}
/**
*
* The identifier of the certificate. Note that in CloudFront, this attribute is deprecated.
*
*
* @param certificate
* The identifier of the certificate. Note that in CloudFront, this attribute is deprecated.
*/
public void setCertificate(String certificate) {
this.certificate = certificate;
}
/**
*
* The identifier of the certificate. Note that in CloudFront, this attribute is deprecated.
*
*
* @return The identifier of the certificate. Note that in CloudFront, this attribute is deprecated.
*/
public String getCertificate() {
return this.certificate;
}
/**
*
* The identifier of the certificate. Note that in CloudFront, this attribute is deprecated.
*
*
* @param certificate
* The identifier of the certificate. Note that in CloudFront, this attribute is deprecated.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public AwsCloudFrontDistributionViewerCertificate withCertificate(String certificate) {
setCertificate(certificate);
return this;
}
/**
*
* The source of the certificate identified by Certificate
. Note that in CloudFront, this attribute is
* deprecated.
*
*
* @param certificateSource
* The source of the certificate identified by Certificate
. Note that in CloudFront, this
* attribute is deprecated.
*/
public void setCertificateSource(String certificateSource) {
this.certificateSource = certificateSource;
}
/**
*
* The source of the certificate identified by Certificate
. Note that in CloudFront, this attribute is
* deprecated.
*
*
* @return The source of the certificate identified by Certificate
. Note that in CloudFront, this
* attribute is deprecated.
*/
public String getCertificateSource() {
return this.certificateSource;
}
/**
*
* The source of the certificate identified by Certificate
. Note that in CloudFront, this attribute is
* deprecated.
*
*
* @param certificateSource
* The source of the certificate identified by Certificate
. Note that in CloudFront, this
* attribute is deprecated.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public AwsCloudFrontDistributionViewerCertificate withCertificateSource(String certificateSource) {
setCertificateSource(certificateSource);
return this;
}
/**
*
* Whether the distribution uses the CloudFront domain name. If set to false
, then you provide either
* AcmCertificateArn
or IamCertificateId
.
*
*
* @param cloudFrontDefaultCertificate
* Whether the distribution uses the CloudFront domain name. If set to false
, then you provide
* either AcmCertificateArn
or IamCertificateId
.
*/
public void setCloudFrontDefaultCertificate(Boolean cloudFrontDefaultCertificate) {
this.cloudFrontDefaultCertificate = cloudFrontDefaultCertificate;
}
/**
*
* Whether the distribution uses the CloudFront domain name. If set to false
, then you provide either
* AcmCertificateArn
or IamCertificateId
.
*
*
* @return Whether the distribution uses the CloudFront domain name. If set to false
, then you provide
* either AcmCertificateArn
or IamCertificateId
.
*/
public Boolean getCloudFrontDefaultCertificate() {
return this.cloudFrontDefaultCertificate;
}
/**
*
* Whether the distribution uses the CloudFront domain name. If set to false
, then you provide either
* AcmCertificateArn
or IamCertificateId
.
*
*
* @param cloudFrontDefaultCertificate
* Whether the distribution uses the CloudFront domain name. If set to false
, then you provide
* either AcmCertificateArn
or IamCertificateId
.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public AwsCloudFrontDistributionViewerCertificate withCloudFrontDefaultCertificate(Boolean cloudFrontDefaultCertificate) {
setCloudFrontDefaultCertificate(cloudFrontDefaultCertificate);
return this;
}
/**
*
* Whether the distribution uses the CloudFront domain name. If set to false
, then you provide either
* AcmCertificateArn
or IamCertificateId
.
*
*
* @return Whether the distribution uses the CloudFront domain name. If set to false
, then you provide
* either AcmCertificateArn
or IamCertificateId
.
*/
public Boolean isCloudFrontDefaultCertificate() {
return this.cloudFrontDefaultCertificate;
}
/**
*
* The identifier of the IAM certificate. Used if the certificate is stored in IAM. If you provide
* IamCertificateId
, then you also must provide MinimumProtocolVersion
and
* SslSupportMethod
.
*
*
* @param iamCertificateId
* The identifier of the IAM certificate. Used if the certificate is stored in IAM. If you provide
* IamCertificateId
, then you also must provide MinimumProtocolVersion
and
* SslSupportMethod
.
*/
public void setIamCertificateId(String iamCertificateId) {
this.iamCertificateId = iamCertificateId;
}
/**
*
* The identifier of the IAM certificate. Used if the certificate is stored in IAM. If you provide
* IamCertificateId
, then you also must provide MinimumProtocolVersion
and
* SslSupportMethod
.
*
*
* @return The identifier of the IAM certificate. Used if the certificate is stored in IAM. If you provide
* IamCertificateId
, then you also must provide MinimumProtocolVersion
and
* SslSupportMethod
.
*/
public String getIamCertificateId() {
return this.iamCertificateId;
}
/**
*
* The identifier of the IAM certificate. Used if the certificate is stored in IAM. If you provide
* IamCertificateId
, then you also must provide MinimumProtocolVersion
and
* SslSupportMethod
.
*
*
* @param iamCertificateId
* The identifier of the IAM certificate. Used if the certificate is stored in IAM. If you provide
* IamCertificateId
, then you also must provide MinimumProtocolVersion
and
* SslSupportMethod
.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public AwsCloudFrontDistributionViewerCertificate withIamCertificateId(String iamCertificateId) {
setIamCertificateId(iamCertificateId);
return this;
}
/**
*
* The security policy that CloudFront uses for HTTPS connections with viewers. If SslSupportMethod
is
* sni-only
, then MinimumProtocolVersion
must be TLSv1
or higher.
*
*
* @param minimumProtocolVersion
* The security policy that CloudFront uses for HTTPS connections with viewers. If
* SslSupportMethod
is sni-only
, then MinimumProtocolVersion
must be
* TLSv1
or higher.
*/
public void setMinimumProtocolVersion(String minimumProtocolVersion) {
this.minimumProtocolVersion = minimumProtocolVersion;
}
/**
*
* The security policy that CloudFront uses for HTTPS connections with viewers. If SslSupportMethod
is
* sni-only
, then MinimumProtocolVersion
must be TLSv1
or higher.
*
*
* @return The security policy that CloudFront uses for HTTPS connections with viewers. If
* SslSupportMethod
is sni-only
, then MinimumProtocolVersion
must be
* TLSv1
or higher.
*/
public String getMinimumProtocolVersion() {
return this.minimumProtocolVersion;
}
/**
*
* The security policy that CloudFront uses for HTTPS connections with viewers. If SslSupportMethod
is
* sni-only
, then MinimumProtocolVersion
must be TLSv1
or higher.
*
*
* @param minimumProtocolVersion
* The security policy that CloudFront uses for HTTPS connections with viewers. If
* SslSupportMethod
is sni-only
, then MinimumProtocolVersion
must be
* TLSv1
or higher.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public AwsCloudFrontDistributionViewerCertificate withMinimumProtocolVersion(String minimumProtocolVersion) {
setMinimumProtocolVersion(minimumProtocolVersion);
return this;
}
/**
*
* The viewers that the distribution accepts HTTPS connections from.
*
*
* @param sslSupportMethod
* The viewers that the distribution accepts HTTPS connections from.
*/
public void setSslSupportMethod(String sslSupportMethod) {
this.sslSupportMethod = sslSupportMethod;
}
/**
*
* The viewers that the distribution accepts HTTPS connections from.
*
*
* @return The viewers that the distribution accepts HTTPS connections from.
*/
public String getSslSupportMethod() {
return this.sslSupportMethod;
}
/**
*
* The viewers that the distribution accepts HTTPS connections from.
*
*
* @param sslSupportMethod
* The viewers that the distribution accepts HTTPS connections from.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public AwsCloudFrontDistributionViewerCertificate withSslSupportMethod(String sslSupportMethod) {
setSslSupportMethod(sslSupportMethod);
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 (getAcmCertificateArn() != null)
sb.append("AcmCertificateArn: ").append(getAcmCertificateArn()).append(",");
if (getCertificate() != null)
sb.append("Certificate: ").append(getCertificate()).append(",");
if (getCertificateSource() != null)
sb.append("CertificateSource: ").append(getCertificateSource()).append(",");
if (getCloudFrontDefaultCertificate() != null)
sb.append("CloudFrontDefaultCertificate: ").append(getCloudFrontDefaultCertificate()).append(",");
if (getIamCertificateId() != null)
sb.append("IamCertificateId: ").append(getIamCertificateId()).append(",");
if (getMinimumProtocolVersion() != null)
sb.append("MinimumProtocolVersion: ").append(getMinimumProtocolVersion()).append(",");
if (getSslSupportMethod() != null)
sb.append("SslSupportMethod: ").append(getSslSupportMethod());
sb.append("}");
return sb.toString();
}
@Override
public boolean equals(Object obj) {
if (this == obj)
return true;
if (obj == null)
return false;
if (obj instanceof AwsCloudFrontDistributionViewerCertificate == false)
return false;
AwsCloudFrontDistributionViewerCertificate other = (AwsCloudFrontDistributionViewerCertificate) obj;
if (other.getAcmCertificateArn() == null ^ this.getAcmCertificateArn() == null)
return false;
if (other.getAcmCertificateArn() != null && other.getAcmCertificateArn().equals(this.getAcmCertificateArn()) == false)
return false;
if (other.getCertificate() == null ^ this.getCertificate() == null)
return false;
if (other.getCertificate() != null && other.getCertificate().equals(this.getCertificate()) == false)
return false;
if (other.getCertificateSource() == null ^ this.getCertificateSource() == null)
return false;
if (other.getCertificateSource() != null && other.getCertificateSource().equals(this.getCertificateSource()) == false)
return false;
if (other.getCloudFrontDefaultCertificate() == null ^ this.getCloudFrontDefaultCertificate() == null)
return false;
if (other.getCloudFrontDefaultCertificate() != null && other.getCloudFrontDefaultCertificate().equals(this.getCloudFrontDefaultCertificate()) == false)
return false;
if (other.getIamCertificateId() == null ^ this.getIamCertificateId() == null)
return false;
if (other.getIamCertificateId() != null && other.getIamCertificateId().equals(this.getIamCertificateId()) == false)
return false;
if (other.getMinimumProtocolVersion() == null ^ this.getMinimumProtocolVersion() == null)
return false;
if (other.getMinimumProtocolVersion() != null && other.getMinimumProtocolVersion().equals(this.getMinimumProtocolVersion()) == false)
return false;
if (other.getSslSupportMethod() == null ^ this.getSslSupportMethod() == null)
return false;
if (other.getSslSupportMethod() != null && other.getSslSupportMethod().equals(this.getSslSupportMethod()) == false)
return false;
return true;
}
@Override
public int hashCode() {
final int prime = 31;
int hashCode = 1;
hashCode = prime * hashCode + ((getAcmCertificateArn() == null) ? 0 : getAcmCertificateArn().hashCode());
hashCode = prime * hashCode + ((getCertificate() == null) ? 0 : getCertificate().hashCode());
hashCode = prime * hashCode + ((getCertificateSource() == null) ? 0 : getCertificateSource().hashCode());
hashCode = prime * hashCode + ((getCloudFrontDefaultCertificate() == null) ? 0 : getCloudFrontDefaultCertificate().hashCode());
hashCode = prime * hashCode + ((getIamCertificateId() == null) ? 0 : getIamCertificateId().hashCode());
hashCode = prime * hashCode + ((getMinimumProtocolVersion() == null) ? 0 : getMinimumProtocolVersion().hashCode());
hashCode = prime * hashCode + ((getSslSupportMethod() == null) ? 0 : getSslSupportMethod().hashCode());
return hashCode;
}
@Override
public AwsCloudFrontDistributionViewerCertificate clone() {
try {
return (AwsCloudFrontDistributionViewerCertificate) 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.AwsCloudFrontDistributionViewerCertificateMarshaller.getInstance()
.marshall(this, protocolMarshaller);
}
}