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

com.amazonaws.services.cloudfront.model.ForwardedValues Maven / Gradle / Ivy

/*
 * Copyright 2011-2016 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;

/**
 * 

* A complex type that specifies how CloudFront handles query strings and cookies. *

*/ public class ForwardedValues implements Serializable, Cloneable { /** *

* Indicates whether you want CloudFront to forward query strings to the origin that is associated with this cache * behavior and cache based on the query string parameters. CloudFront behavior depends on the value of * QueryString and on the values that you specify for QueryStringCacheKeys, if any: *

*

* If you specify true for QueryString and you don't specify any values for * QueryStringCacheKeys, CloudFront forwards all query string parameters to the origin and caches based * on all query string parameters. Depending on how many query string parameters and values you have, this can * adversely affect performance because CloudFront must forward more requests to the origin. *

*

* If you specify true for QueryString and you specify one or more values for * QueryStringCacheKeys, CloudFront forwards all query string parameters to the origin, but it only * caches based on the query string parameters that you specify. *

*

* If you specify false for QueryString, CloudFront doesn't forward any query string parameters to the * origin, and doesn't cache based on query string parameters. *

*

* For more information, see Configuring * CloudFront to Cache Based on Query String Parameters in the Amazon CloudFront Developer Guide. *

*/ private Boolean queryString; /** *

* A complex type that specifies whether you want CloudFront to forward cookies to the origin and, if so, which * ones. For more information about forwarding cookies to the origin, see How CloudFront Forwards, * Caches, and Logs Cookies in the Amazon CloudFront Developer Guide. *

*/ private CookiePreference cookies; /** *

* A complex type that specifies the Headers, if any, that you want CloudFront to vary upon for this * cache behavior. *

*/ private Headers headers; /** *

* A complex type that contains information about the query string parameters that you want CloudFront to use for * caching for this cache behavior. *

*/ private QueryStringCacheKeys queryStringCacheKeys; /** *

* Indicates whether you want CloudFront to forward query strings to the origin that is associated with this cache * behavior and cache based on the query string parameters. CloudFront behavior depends on the value of * QueryString and on the values that you specify for QueryStringCacheKeys, if any: *

*

* If you specify true for QueryString and you don't specify any values for * QueryStringCacheKeys, CloudFront forwards all query string parameters to the origin and caches based * on all query string parameters. Depending on how many query string parameters and values you have, this can * adversely affect performance because CloudFront must forward more requests to the origin. *

*

* If you specify true for QueryString and you specify one or more values for * QueryStringCacheKeys, CloudFront forwards all query string parameters to the origin, but it only * caches based on the query string parameters that you specify. *

*

* If you specify false for QueryString, CloudFront doesn't forward any query string parameters to the * origin, and doesn't cache based on query string parameters. *

*

* For more information, see Configuring * CloudFront to Cache Based on Query String Parameters in the Amazon CloudFront Developer Guide. *

* * @param queryString * Indicates whether you want CloudFront to forward query strings to the origin that is associated with this * cache behavior and cache based on the query string parameters. CloudFront behavior depends on the value of * QueryString and on the values that you specify for QueryStringCacheKeys, if * any:

*

* If you specify true for QueryString and you don't specify any values for * QueryStringCacheKeys, CloudFront forwards all query string parameters to the origin and * caches based on all query string parameters. Depending on how many query string parameters and values you * have, this can adversely affect performance because CloudFront must forward more requests to the origin. *

*

* If you specify true for QueryString and you specify one or more values for * QueryStringCacheKeys, CloudFront forwards all query string parameters to the origin, but it * only caches based on the query string parameters that you specify. *

*

* If you specify false for QueryString, CloudFront doesn't forward any query string parameters * to the origin, and doesn't cache based on query string parameters. *

*

* For more information, see Configuring CloudFront to Cache Based on Query String Parameters in the Amazon CloudFront * Developer Guide. */ public void setQueryString(Boolean queryString) { this.queryString = queryString; } /** *

* Indicates whether you want CloudFront to forward query strings to the origin that is associated with this cache * behavior and cache based on the query string parameters. CloudFront behavior depends on the value of * QueryString and on the values that you specify for QueryStringCacheKeys, if any: *

*

* If you specify true for QueryString and you don't specify any values for * QueryStringCacheKeys, CloudFront forwards all query string parameters to the origin and caches based * on all query string parameters. Depending on how many query string parameters and values you have, this can * adversely affect performance because CloudFront must forward more requests to the origin. *

*

* If you specify true for QueryString and you specify one or more values for * QueryStringCacheKeys, CloudFront forwards all query string parameters to the origin, but it only * caches based on the query string parameters that you specify. *

*

* If you specify false for QueryString, CloudFront doesn't forward any query string parameters to the * origin, and doesn't cache based on query string parameters. *

*

* For more information, see Configuring * CloudFront to Cache Based on Query String Parameters in the Amazon CloudFront Developer Guide. *

* * @return Indicates whether you want CloudFront to forward query strings to the origin that is associated with this * cache behavior and cache based on the query string parameters. CloudFront behavior depends on the value * of QueryString and on the values that you specify for QueryStringCacheKeys, if * any:

*

* If you specify true for QueryString and you don't specify any values for * QueryStringCacheKeys, CloudFront forwards all query string parameters to the origin and * caches based on all query string parameters. Depending on how many query string parameters and values you * have, this can adversely affect performance because CloudFront must forward more requests to the origin. *

*

* If you specify true for QueryString and you specify one or more values for * QueryStringCacheKeys, CloudFront forwards all query string parameters to the origin, but it * only caches based on the query string parameters that you specify. *

*

* If you specify false for QueryString, CloudFront doesn't forward any query string parameters * to the origin, and doesn't cache based on query string parameters. *

*

* For more information, see Configuring CloudFront to Cache Based on Query String Parameters in the Amazon CloudFront * Developer Guide. */ public Boolean getQueryString() { return this.queryString; } /** *

* Indicates whether you want CloudFront to forward query strings to the origin that is associated with this cache * behavior and cache based on the query string parameters. CloudFront behavior depends on the value of * QueryString and on the values that you specify for QueryStringCacheKeys, if any: *

*

* If you specify true for QueryString and you don't specify any values for * QueryStringCacheKeys, CloudFront forwards all query string parameters to the origin and caches based * on all query string parameters. Depending on how many query string parameters and values you have, this can * adversely affect performance because CloudFront must forward more requests to the origin. *

*

* If you specify true for QueryString and you specify one or more values for * QueryStringCacheKeys, CloudFront forwards all query string parameters to the origin, but it only * caches based on the query string parameters that you specify. *

*

* If you specify false for QueryString, CloudFront doesn't forward any query string parameters to the * origin, and doesn't cache based on query string parameters. *

*

* For more information, see Configuring * CloudFront to Cache Based on Query String Parameters in the Amazon CloudFront Developer Guide. *

* * @param queryString * Indicates whether you want CloudFront to forward query strings to the origin that is associated with this * cache behavior and cache based on the query string parameters. CloudFront behavior depends on the value of * QueryString and on the values that you specify for QueryStringCacheKeys, if * any:

*

* If you specify true for QueryString and you don't specify any values for * QueryStringCacheKeys, CloudFront forwards all query string parameters to the origin and * caches based on all query string parameters. Depending on how many query string parameters and values you * have, this can adversely affect performance because CloudFront must forward more requests to the origin. *

*

* If you specify true for QueryString and you specify one or more values for * QueryStringCacheKeys, CloudFront forwards all query string parameters to the origin, but it * only caches based on the query string parameters that you specify. *

*

* If you specify false for QueryString, CloudFront doesn't forward any query string parameters * to the origin, and doesn't cache based on query string parameters. *

*

* For more information, see Configuring CloudFront to Cache Based on Query String Parameters in the Amazon CloudFront * Developer Guide. * @return Returns a reference to this object so that method calls can be chained together. */ public ForwardedValues withQueryString(Boolean queryString) { setQueryString(queryString); return this; } /** *

* Indicates whether you want CloudFront to forward query strings to the origin that is associated with this cache * behavior and cache based on the query string parameters. CloudFront behavior depends on the value of * QueryString and on the values that you specify for QueryStringCacheKeys, if any: *

*

* If you specify true for QueryString and you don't specify any values for * QueryStringCacheKeys, CloudFront forwards all query string parameters to the origin and caches based * on all query string parameters. Depending on how many query string parameters and values you have, this can * adversely affect performance because CloudFront must forward more requests to the origin. *

*

* If you specify true for QueryString and you specify one or more values for * QueryStringCacheKeys, CloudFront forwards all query string parameters to the origin, but it only * caches based on the query string parameters that you specify. *

*

* If you specify false for QueryString, CloudFront doesn't forward any query string parameters to the * origin, and doesn't cache based on query string parameters. *

*

* For more information, see Configuring * CloudFront to Cache Based on Query String Parameters in the Amazon CloudFront Developer Guide. *

* * @return Indicates whether you want CloudFront to forward query strings to the origin that is associated with this * cache behavior and cache based on the query string parameters. CloudFront behavior depends on the value * of QueryString and on the values that you specify for QueryStringCacheKeys, if * any:

*

* If you specify true for QueryString and you don't specify any values for * QueryStringCacheKeys, CloudFront forwards all query string parameters to the origin and * caches based on all query string parameters. Depending on how many query string parameters and values you * have, this can adversely affect performance because CloudFront must forward more requests to the origin. *

*

* If you specify true for QueryString and you specify one or more values for * QueryStringCacheKeys, CloudFront forwards all query string parameters to the origin, but it * only caches based on the query string parameters that you specify. *

*

* If you specify false for QueryString, CloudFront doesn't forward any query string parameters * to the origin, and doesn't cache based on query string parameters. *

*

* For more information, see Configuring CloudFront to Cache Based on Query String Parameters in the Amazon CloudFront * Developer Guide. */ public Boolean isQueryString() { return this.queryString; } /** *

* A complex type that specifies whether you want CloudFront to forward cookies to the origin and, if so, which * ones. For more information about forwarding cookies to the origin, see How CloudFront Forwards, * Caches, and Logs Cookies in the Amazon CloudFront Developer Guide. *

* * @param cookies * A complex type that specifies whether you want CloudFront to forward cookies to the origin and, if so, * which ones. For more information about forwarding cookies to the origin, see How CloudFront * Forwards, Caches, and Logs Cookies in the Amazon CloudFront Developer Guide. */ public void setCookies(CookiePreference cookies) { this.cookies = cookies; } /** *

* A complex type that specifies whether you want CloudFront to forward cookies to the origin and, if so, which * ones. For more information about forwarding cookies to the origin, see How CloudFront Forwards, * Caches, and Logs Cookies in the Amazon CloudFront Developer Guide. *

* * @return A complex type that specifies whether you want CloudFront to forward cookies to the origin and, if so, * which ones. For more information about forwarding cookies to the origin, see How CloudFront * Forwards, Caches, and Logs Cookies in the Amazon CloudFront Developer Guide. */ public CookiePreference getCookies() { return this.cookies; } /** *

* A complex type that specifies whether you want CloudFront to forward cookies to the origin and, if so, which * ones. For more information about forwarding cookies to the origin, see How CloudFront Forwards, * Caches, and Logs Cookies in the Amazon CloudFront Developer Guide. *

* * @param cookies * A complex type that specifies whether you want CloudFront to forward cookies to the origin and, if so, * which ones. For more information about forwarding cookies to the origin, see How CloudFront * Forwards, Caches, and Logs Cookies in the Amazon CloudFront Developer Guide. * @return Returns a reference to this object so that method calls can be chained together. */ public ForwardedValues withCookies(CookiePreference cookies) { setCookies(cookies); return this; } /** *

* A complex type that specifies the Headers, if any, that you want CloudFront to vary upon for this * cache behavior. *

* * @param headers * A complex type that specifies the Headers, if any, that you want CloudFront to vary upon for * this cache behavior. */ public void setHeaders(Headers headers) { this.headers = headers; } /** *

* A complex type that specifies the Headers, if any, that you want CloudFront to vary upon for this * cache behavior. *

* * @return A complex type that specifies the Headers, if any, that you want CloudFront to vary upon for * this cache behavior. */ public Headers getHeaders() { return this.headers; } /** *

* A complex type that specifies the Headers, if any, that you want CloudFront to vary upon for this * cache behavior. *

* * @param headers * A complex type that specifies the Headers, if any, that you want CloudFront to vary upon for * this cache behavior. * @return Returns a reference to this object so that method calls can be chained together. */ public ForwardedValues withHeaders(Headers headers) { setHeaders(headers); return this; } /** *

* A complex type that contains information about the query string parameters that you want CloudFront to use for * caching for this cache behavior. *

* * @param queryStringCacheKeys * A complex type that contains information about the query string parameters that you want CloudFront to use * for caching for this cache behavior. */ public void setQueryStringCacheKeys(QueryStringCacheKeys queryStringCacheKeys) { this.queryStringCacheKeys = queryStringCacheKeys; } /** *

* A complex type that contains information about the query string parameters that you want CloudFront to use for * caching for this cache behavior. *

* * @return A complex type that contains information about the query string parameters that you want CloudFront to * use for caching for this cache behavior. */ public QueryStringCacheKeys getQueryStringCacheKeys() { return this.queryStringCacheKeys; } /** *

* A complex type that contains information about the query string parameters that you want CloudFront to use for * caching for this cache behavior. *

* * @param queryStringCacheKeys * A complex type that contains information about the query string parameters that you want CloudFront to use * for caching for this cache behavior. * @return Returns a reference to this object so that method calls can be chained together. */ public ForwardedValues withQueryStringCacheKeys(QueryStringCacheKeys queryStringCacheKeys) { setQueryStringCacheKeys(queryStringCacheKeys); return this; } /** * Returns a string representation of this object; useful for testing and debugging. * * @return A string representation of this object. * * @see java.lang.Object#toString() */ @Override public String toString() { StringBuilder sb = new StringBuilder(); sb.append("{"); if (getQueryString() != null) sb.append("QueryString: ").append(getQueryString()).append(","); if (getCookies() != null) sb.append("Cookies: ").append(getCookies()).append(","); if (getHeaders() != null) sb.append("Headers: ").append(getHeaders()).append(","); if (getQueryStringCacheKeys() != null) sb.append("QueryStringCacheKeys: ").append(getQueryStringCacheKeys()); sb.append("}"); return sb.toString(); } @Override public boolean equals(Object obj) { if (this == obj) return true; if (obj == null) return false; if (obj instanceof ForwardedValues == false) return false; ForwardedValues other = (ForwardedValues) obj; if (other.getQueryString() == null ^ this.getQueryString() == null) return false; if (other.getQueryString() != null && other.getQueryString().equals(this.getQueryString()) == false) return false; if (other.getCookies() == null ^ this.getCookies() == null) return false; if (other.getCookies() != null && other.getCookies().equals(this.getCookies()) == false) return false; if (other.getHeaders() == null ^ this.getHeaders() == null) return false; if (other.getHeaders() != null && other.getHeaders().equals(this.getHeaders()) == false) return false; if (other.getQueryStringCacheKeys() == null ^ this.getQueryStringCacheKeys() == null) return false; if (other.getQueryStringCacheKeys() != null && other.getQueryStringCacheKeys().equals(this.getQueryStringCacheKeys()) == false) return false; return true; } @Override public int hashCode() { final int prime = 31; int hashCode = 1; hashCode = prime * hashCode + ((getQueryString() == null) ? 0 : getQueryString().hashCode()); hashCode = prime * hashCode + ((getCookies() == null) ? 0 : getCookies().hashCode()); hashCode = prime * hashCode + ((getHeaders() == null) ? 0 : getHeaders().hashCode()); hashCode = prime * hashCode + ((getQueryStringCacheKeys() == null) ? 0 : getQueryStringCacheKeys().hashCode()); return hashCode; } @Override public ForwardedValues clone() { try { return (ForwardedValues) 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