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);
}
}
}