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

com.amazonaws.services.cloudfront.model.CachePolicyConfig 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;

/**
 * 

* A cache policy configuration. *

*

* This configuration determines the following: *

*
    *
  • *

    * The values that CloudFront includes in the cache key. These values can include HTTP headers, cookies, and URL query * strings. CloudFront uses the cache key to find an object in its cache that it can return to the viewer. *

    *
  • *
  • *

    * The default, minimum, and maximum time to live (TTL) values that you want objects to stay in the CloudFront cache. *

    *
  • *
*

* The headers, cookies, and query strings that are included in the cache key are also included in requests that * CloudFront sends to the origin. CloudFront sends a request when it can't find a valid object in its cache that * matches the request's cache key. If you want to send values to the origin but not include them in the cache * key, use OriginRequestPolicy. *

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

* A comment to describe the cache policy. The comment cannot be longer than 128 characters. *

*/ private String comment; /** *

* A unique name to identify the cache policy. *

*/ private String name; /** *

* The default amount of time, in seconds, that you want objects to stay in the CloudFront cache before CloudFront * sends another request to the origin to see if the object has been updated. CloudFront uses this value as the * object's time to live (TTL) only when the origin does not send Cache-Control or * Expires headers with the object. For more information, see Managing How Long * Content Stays in an Edge Cache (Expiration) in the Amazon CloudFront Developer Guide. *

*

* The default value for this field is 86400 seconds (one day). If the value of MinTTL is more than * 86400 seconds, then the default value for this field is the same as the value of MinTTL. *

*/ private Long defaultTTL; /** *

* The maximum amount of time, in seconds, that objects stay in the CloudFront cache before CloudFront sends another * request to the origin to see if the object has been updated. CloudFront uses this value only when the origin * sends Cache-Control or Expires headers with the object. For more information, see Managing How Long * Content Stays in an Edge Cache (Expiration) in the Amazon CloudFront Developer Guide. *

*

* The default value for this field is 31536000 seconds (one year). If the value of MinTTL or * DefaultTTL is more than 31536000 seconds, then the default value for this field is the same as the * value of DefaultTTL. *

*/ private Long maxTTL; /** *

* The minimum amount of time, in seconds, that you want objects to stay in the CloudFront cache before CloudFront * sends another request to the origin to see if the object has been updated. For more information, see Managing How Long * Content Stays in an Edge Cache (Expiration) in the Amazon CloudFront Developer Guide. *

*/ private Long minTTL; /** *

* The HTTP headers, cookies, and URL query strings to include in the cache key. The values included in the cache * key are also included in requests that CloudFront sends to the origin. *

*/ private ParametersInCacheKeyAndForwardedToOrigin parametersInCacheKeyAndForwardedToOrigin; /** *

* A comment to describe the cache policy. The comment cannot be longer than 128 characters. *

* * @param comment * A comment to describe the cache policy. The comment cannot be longer than 128 characters. */ public void setComment(String comment) { this.comment = comment; } /** *

* A comment to describe the cache policy. The comment cannot be longer than 128 characters. *

* * @return A comment to describe the cache policy. The comment cannot be longer than 128 characters. */ public String getComment() { return this.comment; } /** *

* A comment to describe the cache policy. The comment cannot be longer than 128 characters. *

* * @param comment * A comment to describe the cache 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 CachePolicyConfig withComment(String comment) { setComment(comment); return this; } /** *

* A unique name to identify the cache policy. *

* * @param name * A unique name to identify the cache policy. */ public void setName(String name) { this.name = name; } /** *

* A unique name to identify the cache policy. *

* * @return A unique name to identify the cache policy. */ public String getName() { return this.name; } /** *

* A unique name to identify the cache policy. *

* * @param name * A unique name to identify the cache policy. * @return Returns a reference to this object so that method calls can be chained together. */ public CachePolicyConfig withName(String name) { setName(name); return this; } /** *

* The default amount of time, in seconds, that you want objects to stay in the CloudFront cache before CloudFront * sends another request to the origin to see if the object has been updated. CloudFront uses this value as the * object's time to live (TTL) only when the origin does not send Cache-Control or * Expires headers with the object. For more information, see Managing How Long * Content Stays in an Edge Cache (Expiration) in the Amazon CloudFront Developer Guide. *

*

* The default value for this field is 86400 seconds (one day). If the value of MinTTL is more than * 86400 seconds, then the default value for this field is the same as the value of MinTTL. *

* * @param defaultTTL * The default amount of time, in seconds, that you want objects to stay in the CloudFront cache before * CloudFront sends another request to the origin to see if the object has been updated. CloudFront uses this * value as the object's time to live (TTL) only when the origin does not send * Cache-Control or Expires headers with the object. For more information, see Managing How * Long Content Stays in an Edge Cache (Expiration) in the Amazon CloudFront Developer Guide.

*

* The default value for this field is 86400 seconds (one day). If the value of MinTTL is more * than 86400 seconds, then the default value for this field is the same as the value of MinTTL. */ public void setDefaultTTL(Long defaultTTL) { this.defaultTTL = defaultTTL; } /** *

* The default amount of time, in seconds, that you want objects to stay in the CloudFront cache before CloudFront * sends another request to the origin to see if the object has been updated. CloudFront uses this value as the * object's time to live (TTL) only when the origin does not send Cache-Control or * Expires headers with the object. For more information, see Managing How Long * Content Stays in an Edge Cache (Expiration) in the Amazon CloudFront Developer Guide. *

*

* The default value for this field is 86400 seconds (one day). If the value of MinTTL is more than * 86400 seconds, then the default value for this field is the same as the value of MinTTL. *

* * @return The default amount of time, in seconds, that you want objects to stay in the CloudFront cache before * CloudFront sends another request to the origin to see if the object has been updated. CloudFront uses * this value as the object's time to live (TTL) only when the origin does not send * Cache-Control or Expires headers with the object. For more information, see Managing How * Long Content Stays in an Edge Cache (Expiration) in the Amazon CloudFront Developer Guide.

*

* The default value for this field is 86400 seconds (one day). If the value of MinTTL is more * than 86400 seconds, then the default value for this field is the same as the value of MinTTL. */ public Long getDefaultTTL() { return this.defaultTTL; } /** *

* The default amount of time, in seconds, that you want objects to stay in the CloudFront cache before CloudFront * sends another request to the origin to see if the object has been updated. CloudFront uses this value as the * object's time to live (TTL) only when the origin does not send Cache-Control or * Expires headers with the object. For more information, see Managing How Long * Content Stays in an Edge Cache (Expiration) in the Amazon CloudFront Developer Guide. *

*

* The default value for this field is 86400 seconds (one day). If the value of MinTTL is more than * 86400 seconds, then the default value for this field is the same as the value of MinTTL. *

* * @param defaultTTL * The default amount of time, in seconds, that you want objects to stay in the CloudFront cache before * CloudFront sends another request to the origin to see if the object has been updated. CloudFront uses this * value as the object's time to live (TTL) only when the origin does not send * Cache-Control or Expires headers with the object. For more information, see Managing How * Long Content Stays in an Edge Cache (Expiration) in the Amazon CloudFront Developer Guide.

*

* The default value for this field is 86400 seconds (one day). If the value of MinTTL is more * than 86400 seconds, then the default value for this field is the same as the value of MinTTL. * @return Returns a reference to this object so that method calls can be chained together. */ public CachePolicyConfig withDefaultTTL(Long defaultTTL) { setDefaultTTL(defaultTTL); return this; } /** *

* The maximum amount of time, in seconds, that objects stay in the CloudFront cache before CloudFront sends another * request to the origin to see if the object has been updated. CloudFront uses this value only when the origin * sends Cache-Control or Expires headers with the object. For more information, see Managing How Long * Content Stays in an Edge Cache (Expiration) in the Amazon CloudFront Developer Guide. *

*

* The default value for this field is 31536000 seconds (one year). If the value of MinTTL or * DefaultTTL is more than 31536000 seconds, then the default value for this field is the same as the * value of DefaultTTL. *

* * @param maxTTL * The maximum amount of time, in seconds, that objects stay in the CloudFront cache before CloudFront sends * another request to the origin to see if the object has been updated. CloudFront uses this value only when * the origin sends Cache-Control or Expires headers with the object. For more * information, see Managing How * Long Content Stays in an Edge Cache (Expiration) in the Amazon CloudFront Developer Guide.

*

* The default value for this field is 31536000 seconds (one year). If the value of MinTTL or * DefaultTTL is more than 31536000 seconds, then the default value for this field is the same * as the value of DefaultTTL. */ public void setMaxTTL(Long maxTTL) { this.maxTTL = maxTTL; } /** *

* The maximum amount of time, in seconds, that objects stay in the CloudFront cache before CloudFront sends another * request to the origin to see if the object has been updated. CloudFront uses this value only when the origin * sends Cache-Control or Expires headers with the object. For more information, see Managing How Long * Content Stays in an Edge Cache (Expiration) in the Amazon CloudFront Developer Guide. *

*

* The default value for this field is 31536000 seconds (one year). If the value of MinTTL or * DefaultTTL is more than 31536000 seconds, then the default value for this field is the same as the * value of DefaultTTL. *

* * @return The maximum amount of time, in seconds, that objects stay in the CloudFront cache before CloudFront sends * another request to the origin to see if the object has been updated. CloudFront uses this value only when * the origin sends Cache-Control or Expires headers with the object. For more * information, see Managing How * Long Content Stays in an Edge Cache (Expiration) in the Amazon CloudFront Developer Guide.

*

* The default value for this field is 31536000 seconds (one year). If the value of MinTTL or * DefaultTTL is more than 31536000 seconds, then the default value for this field is the same * as the value of DefaultTTL. */ public Long getMaxTTL() { return this.maxTTL; } /** *

* The maximum amount of time, in seconds, that objects stay in the CloudFront cache before CloudFront sends another * request to the origin to see if the object has been updated. CloudFront uses this value only when the origin * sends Cache-Control or Expires headers with the object. For more information, see Managing How Long * Content Stays in an Edge Cache (Expiration) in the Amazon CloudFront Developer Guide. *

*

* The default value for this field is 31536000 seconds (one year). If the value of MinTTL or * DefaultTTL is more than 31536000 seconds, then the default value for this field is the same as the * value of DefaultTTL. *

* * @param maxTTL * The maximum amount of time, in seconds, that objects stay in the CloudFront cache before CloudFront sends * another request to the origin to see if the object has been updated. CloudFront uses this value only when * the origin sends Cache-Control or Expires headers with the object. For more * information, see Managing How * Long Content Stays in an Edge Cache (Expiration) in the Amazon CloudFront Developer Guide.

*

* The default value for this field is 31536000 seconds (one year). If the value of MinTTL or * DefaultTTL is more than 31536000 seconds, then the default value for this field is the same * as the value of DefaultTTL. * @return Returns a reference to this object so that method calls can be chained together. */ public CachePolicyConfig withMaxTTL(Long maxTTL) { setMaxTTL(maxTTL); return this; } /** *

* The minimum amount of time, in seconds, that you want objects to stay in the CloudFront cache before CloudFront * sends another request to the origin to see if the object has been updated. For more information, see Managing How Long * Content Stays in an Edge Cache (Expiration) in the Amazon CloudFront Developer Guide. *

* * @param minTTL * The minimum amount of time, in seconds, that you want objects to stay in the CloudFront cache before * CloudFront sends another request to the origin to see if the object has been updated. For more * information, see Managing How * Long Content Stays in an Edge Cache (Expiration) in the Amazon CloudFront Developer Guide. */ public void setMinTTL(Long minTTL) { this.minTTL = minTTL; } /** *

* The minimum amount of time, in seconds, that you want objects to stay in the CloudFront cache before CloudFront * sends another request to the origin to see if the object has been updated. For more information, see Managing How Long * Content Stays in an Edge Cache (Expiration) in the Amazon CloudFront Developer Guide. *

* * @return The minimum amount of time, in seconds, that you want objects to stay in the CloudFront cache before * CloudFront sends another request to the origin to see if the object has been updated. For more * information, see Managing How * Long Content Stays in an Edge Cache (Expiration) in the Amazon CloudFront Developer Guide. */ public Long getMinTTL() { return this.minTTL; } /** *

* The minimum amount of time, in seconds, that you want objects to stay in the CloudFront cache before CloudFront * sends another request to the origin to see if the object has been updated. For more information, see Managing How Long * Content Stays in an Edge Cache (Expiration) in the Amazon CloudFront Developer Guide. *

* * @param minTTL * The minimum amount of time, in seconds, that you want objects to stay in the CloudFront cache before * CloudFront sends another request to the origin to see if the object has been updated. For more * information, see Managing How * Long Content Stays in an Edge Cache (Expiration) in the Amazon CloudFront Developer Guide. * @return Returns a reference to this object so that method calls can be chained together. */ public CachePolicyConfig withMinTTL(Long minTTL) { setMinTTL(minTTL); return this; } /** *

* The HTTP headers, cookies, and URL query strings to include in the cache key. The values included in the cache * key are also included in requests that CloudFront sends to the origin. *

* * @param parametersInCacheKeyAndForwardedToOrigin * The HTTP headers, cookies, and URL query strings to include in the cache key. The values included in the * cache key are also included in requests that CloudFront sends to the origin. */ public void setParametersInCacheKeyAndForwardedToOrigin(ParametersInCacheKeyAndForwardedToOrigin parametersInCacheKeyAndForwardedToOrigin) { this.parametersInCacheKeyAndForwardedToOrigin = parametersInCacheKeyAndForwardedToOrigin; } /** *

* The HTTP headers, cookies, and URL query strings to include in the cache key. The values included in the cache * key are also included in requests that CloudFront sends to the origin. *

* * @return The HTTP headers, cookies, and URL query strings to include in the cache key. The values included in the * cache key are also included in requests that CloudFront sends to the origin. */ public ParametersInCacheKeyAndForwardedToOrigin getParametersInCacheKeyAndForwardedToOrigin() { return this.parametersInCacheKeyAndForwardedToOrigin; } /** *

* The HTTP headers, cookies, and URL query strings to include in the cache key. The values included in the cache * key are also included in requests that CloudFront sends to the origin. *

* * @param parametersInCacheKeyAndForwardedToOrigin * The HTTP headers, cookies, and URL query strings to include in the cache key. The values included in the * cache key are also included in requests that CloudFront sends to the origin. * @return Returns a reference to this object so that method calls can be chained together. */ public CachePolicyConfig withParametersInCacheKeyAndForwardedToOrigin(ParametersInCacheKeyAndForwardedToOrigin parametersInCacheKeyAndForwardedToOrigin) { setParametersInCacheKeyAndForwardedToOrigin(parametersInCacheKeyAndForwardedToOrigin); 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 (getDefaultTTL() != null) sb.append("DefaultTTL: ").append(getDefaultTTL()).append(","); if (getMaxTTL() != null) sb.append("MaxTTL: ").append(getMaxTTL()).append(","); if (getMinTTL() != null) sb.append("MinTTL: ").append(getMinTTL()).append(","); if (getParametersInCacheKeyAndForwardedToOrigin() != null) sb.append("ParametersInCacheKeyAndForwardedToOrigin: ").append(getParametersInCacheKeyAndForwardedToOrigin()); sb.append("}"); return sb.toString(); } @Override public boolean equals(Object obj) { if (this == obj) return true; if (obj == null) return false; if (obj instanceof CachePolicyConfig == false) return false; CachePolicyConfig other = (CachePolicyConfig) 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.getDefaultTTL() == null ^ this.getDefaultTTL() == null) return false; if (other.getDefaultTTL() != null && other.getDefaultTTL().equals(this.getDefaultTTL()) == false) return false; if (other.getMaxTTL() == null ^ this.getMaxTTL() == null) return false; if (other.getMaxTTL() != null && other.getMaxTTL().equals(this.getMaxTTL()) == false) return false; if (other.getMinTTL() == null ^ this.getMinTTL() == null) return false; if (other.getMinTTL() != null && other.getMinTTL().equals(this.getMinTTL()) == false) return false; if (other.getParametersInCacheKeyAndForwardedToOrigin() == null ^ this.getParametersInCacheKeyAndForwardedToOrigin() == null) return false; if (other.getParametersInCacheKeyAndForwardedToOrigin() != null && other.getParametersInCacheKeyAndForwardedToOrigin().equals(this.getParametersInCacheKeyAndForwardedToOrigin()) == 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 + ((getDefaultTTL() == null) ? 0 : getDefaultTTL().hashCode()); hashCode = prime * hashCode + ((getMaxTTL() == null) ? 0 : getMaxTTL().hashCode()); hashCode = prime * hashCode + ((getMinTTL() == null) ? 0 : getMinTTL().hashCode()); hashCode = prime * hashCode + ((getParametersInCacheKeyAndForwardedToOrigin() == null) ? 0 : getParametersInCacheKeyAndForwardedToOrigin().hashCode()); return hashCode; } @Override public CachePolicyConfig clone() { try { return (CachePolicyConfig) super.clone(); } catch (CloneNotSupportedException e) { throw new IllegalStateException("Got a CloneNotSupportedException from Object.clone() " + "even though we're Cloneable!", e); } } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy