com.amazonaws.services.cloudfront.model.ResponseHeadersPolicyConfig 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.cloudfront.model;
import java.io.Serializable;
import javax.annotation.Generated;
/**
*
* A response headers policy configuration.
*
*
* A response headers policy configuration contains metadata about the response headers policy, and configurations for
* sets of HTTP response headers.
*
*
* @see AWS API Documentation
*/
@Generated("com.amazonaws:aws-java-sdk-code-generator")
public class ResponseHeadersPolicyConfig implements Serializable, Cloneable {
/**
*
* A comment to describe the response headers policy.
*
*
* The comment cannot be longer than 128 characters.
*
*/
private String comment;
/**
*
* A name to identify the response headers policy.
*
*
* The name must be unique for response headers policies in this Amazon Web Services account.
*
*/
private String name;
/**
*
* A configuration for a set of HTTP response headers that are used for cross-origin resource sharing (CORS).
*
*/
private ResponseHeadersPolicyCorsConfig corsConfig;
/**
*
* A configuration for a set of security-related HTTP response headers.
*
*/
private ResponseHeadersPolicySecurityHeadersConfig securityHeadersConfig;
/**
*
* A configuration for enabling the Server-Timing
header in HTTP responses sent from CloudFront.
*
*/
private ResponseHeadersPolicyServerTimingHeadersConfig serverTimingHeadersConfig;
/**
*
* A configuration for a set of custom HTTP response headers.
*
*/
private ResponseHeadersPolicyCustomHeadersConfig customHeadersConfig;
/**
*
* A configuration for a set of HTTP headers to remove from the HTTP response.
*
*/
private ResponseHeadersPolicyRemoveHeadersConfig removeHeadersConfig;
/**
*
* A comment to describe the response headers policy.
*
*
* The comment cannot be longer than 128 characters.
*
*
* @param comment
* A comment to describe the response headers policy.
*
* The comment cannot be longer than 128 characters.
*/
public void setComment(String comment) {
this.comment = comment;
}
/**
*
* A comment to describe the response headers policy.
*
*
* The comment cannot be longer than 128 characters.
*
*
* @return A comment to describe the response headers policy.
*
* The comment cannot be longer than 128 characters.
*/
public String getComment() {
return this.comment;
}
/**
*
* A comment to describe the response headers policy.
*
*
* The comment cannot be longer than 128 characters.
*
*
* @param comment
* A comment to describe the response headers policy.
*
* The comment cannot be longer than 128 characters.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public ResponseHeadersPolicyConfig withComment(String comment) {
setComment(comment);
return this;
}
/**
*
* A name to identify the response headers policy.
*
*
* The name must be unique for response headers policies in this Amazon Web Services account.
*
*
* @param name
* A name to identify the response headers policy.
*
* The name must be unique for response headers policies in this Amazon Web Services account.
*/
public void setName(String name) {
this.name = name;
}
/**
*
* A name to identify the response headers policy.
*
*
* The name must be unique for response headers policies in this Amazon Web Services account.
*
*
* @return A name to identify the response headers policy.
*
* The name must be unique for response headers policies in this Amazon Web Services account.
*/
public String getName() {
return this.name;
}
/**
*
* A name to identify the response headers policy.
*
*
* The name must be unique for response headers policies in this Amazon Web Services account.
*
*
* @param name
* A name to identify the response headers policy.
*
* The name must be unique for response headers policies in this Amazon Web Services account.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public ResponseHeadersPolicyConfig withName(String name) {
setName(name);
return this;
}
/**
*
* A configuration for a set of HTTP response headers that are used for cross-origin resource sharing (CORS).
*
*
* @param corsConfig
* A configuration for a set of HTTP response headers that are used for cross-origin resource sharing (CORS).
*/
public void setCorsConfig(ResponseHeadersPolicyCorsConfig corsConfig) {
this.corsConfig = corsConfig;
}
/**
*
* A configuration for a set of HTTP response headers that are used for cross-origin resource sharing (CORS).
*
*
* @return A configuration for a set of HTTP response headers that are used for cross-origin resource sharing
* (CORS).
*/
public ResponseHeadersPolicyCorsConfig getCorsConfig() {
return this.corsConfig;
}
/**
*
* A configuration for a set of HTTP response headers that are used for cross-origin resource sharing (CORS).
*
*
* @param corsConfig
* A configuration for a set of HTTP response headers that are used for cross-origin resource sharing (CORS).
* @return Returns a reference to this object so that method calls can be chained together.
*/
public ResponseHeadersPolicyConfig withCorsConfig(ResponseHeadersPolicyCorsConfig corsConfig) {
setCorsConfig(corsConfig);
return this;
}
/**
*
* A configuration for a set of security-related HTTP response headers.
*
*
* @param securityHeadersConfig
* A configuration for a set of security-related HTTP response headers.
*/
public void setSecurityHeadersConfig(ResponseHeadersPolicySecurityHeadersConfig securityHeadersConfig) {
this.securityHeadersConfig = securityHeadersConfig;
}
/**
*
* A configuration for a set of security-related HTTP response headers.
*
*
* @return A configuration for a set of security-related HTTP response headers.
*/
public ResponseHeadersPolicySecurityHeadersConfig getSecurityHeadersConfig() {
return this.securityHeadersConfig;
}
/**
*
* A configuration for a set of security-related HTTP response headers.
*
*
* @param securityHeadersConfig
* A configuration for a set of security-related HTTP response headers.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public ResponseHeadersPolicyConfig withSecurityHeadersConfig(ResponseHeadersPolicySecurityHeadersConfig securityHeadersConfig) {
setSecurityHeadersConfig(securityHeadersConfig);
return this;
}
/**
*
* A configuration for enabling the Server-Timing
header in HTTP responses sent from CloudFront.
*
*
* @param serverTimingHeadersConfig
* A configuration for enabling the Server-Timing
header in HTTP responses sent from CloudFront.
*/
public void setServerTimingHeadersConfig(ResponseHeadersPolicyServerTimingHeadersConfig serverTimingHeadersConfig) {
this.serverTimingHeadersConfig = serverTimingHeadersConfig;
}
/**
*
* A configuration for enabling the Server-Timing
header in HTTP responses sent from CloudFront.
*
*
* @return A configuration for enabling the Server-Timing
header in HTTP responses sent from
* CloudFront.
*/
public ResponseHeadersPolicyServerTimingHeadersConfig getServerTimingHeadersConfig() {
return this.serverTimingHeadersConfig;
}
/**
*
* A configuration for enabling the Server-Timing
header in HTTP responses sent from CloudFront.
*
*
* @param serverTimingHeadersConfig
* A configuration for enabling the Server-Timing
header in HTTP responses sent from CloudFront.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public ResponseHeadersPolicyConfig withServerTimingHeadersConfig(ResponseHeadersPolicyServerTimingHeadersConfig serverTimingHeadersConfig) {
setServerTimingHeadersConfig(serverTimingHeadersConfig);
return this;
}
/**
*
* A configuration for a set of custom HTTP response headers.
*
*
* @param customHeadersConfig
* A configuration for a set of custom HTTP response headers.
*/
public void setCustomHeadersConfig(ResponseHeadersPolicyCustomHeadersConfig customHeadersConfig) {
this.customHeadersConfig = customHeadersConfig;
}
/**
*
* A configuration for a set of custom HTTP response headers.
*
*
* @return A configuration for a set of custom HTTP response headers.
*/
public ResponseHeadersPolicyCustomHeadersConfig getCustomHeadersConfig() {
return this.customHeadersConfig;
}
/**
*
* A configuration for a set of custom HTTP response headers.
*
*
* @param customHeadersConfig
* A configuration for a set of custom HTTP response headers.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public ResponseHeadersPolicyConfig withCustomHeadersConfig(ResponseHeadersPolicyCustomHeadersConfig customHeadersConfig) {
setCustomHeadersConfig(customHeadersConfig);
return this;
}
/**
*
* A configuration for a set of HTTP headers to remove from the HTTP response.
*
*
* @param removeHeadersConfig
* A configuration for a set of HTTP headers to remove from the HTTP response.
*/
public void setRemoveHeadersConfig(ResponseHeadersPolicyRemoveHeadersConfig removeHeadersConfig) {
this.removeHeadersConfig = removeHeadersConfig;
}
/**
*
* A configuration for a set of HTTP headers to remove from the HTTP response.
*
*
* @return A configuration for a set of HTTP headers to remove from the HTTP response.
*/
public ResponseHeadersPolicyRemoveHeadersConfig getRemoveHeadersConfig() {
return this.removeHeadersConfig;
}
/**
*
* A configuration for a set of HTTP headers to remove from the HTTP response.
*
*
* @param removeHeadersConfig
* A configuration for a set of HTTP headers to remove from the HTTP response.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public ResponseHeadersPolicyConfig withRemoveHeadersConfig(ResponseHeadersPolicyRemoveHeadersConfig removeHeadersConfig) {
setRemoveHeadersConfig(removeHeadersConfig);
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 (getComment() != null)
sb.append("Comment: ").append(getComment()).append(",");
if (getName() != null)
sb.append("Name: ").append(getName()).append(",");
if (getCorsConfig() != null)
sb.append("CorsConfig: ").append(getCorsConfig()).append(",");
if (getSecurityHeadersConfig() != null)
sb.append("SecurityHeadersConfig: ").append(getSecurityHeadersConfig()).append(",");
if (getServerTimingHeadersConfig() != null)
sb.append("ServerTimingHeadersConfig: ").append(getServerTimingHeadersConfig()).append(",");
if (getCustomHeadersConfig() != null)
sb.append("CustomHeadersConfig: ").append(getCustomHeadersConfig()).append(",");
if (getRemoveHeadersConfig() != null)
sb.append("RemoveHeadersConfig: ").append(getRemoveHeadersConfig());
sb.append("}");
return sb.toString();
}
@Override
public boolean equals(Object obj) {
if (this == obj)
return true;
if (obj == null)
return false;
if (obj instanceof ResponseHeadersPolicyConfig == false)
return false;
ResponseHeadersPolicyConfig other = (ResponseHeadersPolicyConfig) obj;
if (other.getComment() == null ^ this.getComment() == null)
return false;
if (other.getComment() != null && other.getComment().equals(this.getComment()) == false)
return false;
if (other.getName() == null ^ this.getName() == null)
return false;
if (other.getName() != null && other.getName().equals(this.getName()) == false)
return false;
if (other.getCorsConfig() == null ^ this.getCorsConfig() == null)
return false;
if (other.getCorsConfig() != null && other.getCorsConfig().equals(this.getCorsConfig()) == false)
return false;
if (other.getSecurityHeadersConfig() == null ^ this.getSecurityHeadersConfig() == null)
return false;
if (other.getSecurityHeadersConfig() != null && other.getSecurityHeadersConfig().equals(this.getSecurityHeadersConfig()) == false)
return false;
if (other.getServerTimingHeadersConfig() == null ^ this.getServerTimingHeadersConfig() == null)
return false;
if (other.getServerTimingHeadersConfig() != null && other.getServerTimingHeadersConfig().equals(this.getServerTimingHeadersConfig()) == false)
return false;
if (other.getCustomHeadersConfig() == null ^ this.getCustomHeadersConfig() == null)
return false;
if (other.getCustomHeadersConfig() != null && other.getCustomHeadersConfig().equals(this.getCustomHeadersConfig()) == false)
return false;
if (other.getRemoveHeadersConfig() == null ^ this.getRemoveHeadersConfig() == null)
return false;
if (other.getRemoveHeadersConfig() != null && other.getRemoveHeadersConfig().equals(this.getRemoveHeadersConfig()) == false)
return false;
return true;
}
@Override
public int hashCode() {
final int prime = 31;
int hashCode = 1;
hashCode = prime * hashCode + ((getComment() == null) ? 0 : getComment().hashCode());
hashCode = prime * hashCode + ((getName() == null) ? 0 : getName().hashCode());
hashCode = prime * hashCode + ((getCorsConfig() == null) ? 0 : getCorsConfig().hashCode());
hashCode = prime * hashCode + ((getSecurityHeadersConfig() == null) ? 0 : getSecurityHeadersConfig().hashCode());
hashCode = prime * hashCode + ((getServerTimingHeadersConfig() == null) ? 0 : getServerTimingHeadersConfig().hashCode());
hashCode = prime * hashCode + ((getCustomHeadersConfig() == null) ? 0 : getCustomHeadersConfig().hashCode());
hashCode = prime * hashCode + ((getRemoveHeadersConfig() == null) ? 0 : getRemoveHeadersConfig().hashCode());
return hashCode;
}
@Override
public ResponseHeadersPolicyConfig clone() {
try {
return (ResponseHeadersPolicyConfig) super.clone();
} catch (CloneNotSupportedException e) {
throw new IllegalStateException("Got a CloneNotSupportedException from Object.clone() " + "even though we're Cloneable!", e);
}
}
}