View Javadoc

1   /**
2    * This file Copyright (c) 2010-2011 Magnolia International
3    * Ltd.  (http://www.magnolia-cms.com). All rights reserved.
4    *
5    *
6    * This file is dual-licensed under both the Magnolia
7    * Network Agreement and the GNU General Public License.
8    * You may elect to use one or the other of these licenses.
9    *
10   * This file is distributed in the hope that it will be
11   * useful, but AS-IS and WITHOUT ANY WARRANTY; without even the
12   * implied warranty of MERCHANTABILITY or FITNESS FOR A
13   * PARTICULAR PURPOSE, TITLE, or NONINFRINGEMENT.
14   * Redistribution, except as permitted by whichever of the GPL
15   * or MNA you select, is prohibited.
16   *
17   * 1. For the GPL license (GPL), you can redistribute and/or
18   * modify this file under the terms of the GNU General
19   * Public License, Version 3, as published by the Free Software
20   * Foundation.  You should have received a copy of the GNU
21   * General Public License, Version 3 along with this program;
22   * if not, write to the Free Software Foundation, Inc., 51
23   * Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
24   *
25   * 2. For the Magnolia Network Agreement (MNA), this file
26   * and the accompanying materials are made available under the
27   * terms of the MNA which accompanies this distribution, and
28   * is available at http://www.magnolia-cms.com/mna.html
29   *
30   * Any modifications to this file must keep this entire header
31   * intact.
32   *
33   */
34  package info.magnolia.module.cache;
35  
36  import java.io.Serializable;
37  import java.util.Map;
38  
39  import edu.emory.mathcs.backport.java.util.Collections;
40  
41  /**
42   * Default cache key implementation. Key is based on the URI, server name, parameters and request headers. Since the server name is likely to change from server to server, copying cached items around will most likely not help to avoid generating cache entries.
43   *
44   * @author had
45   * @version $Id:$
46   */
47  public class DefaultCacheKey implements Serializable {
48  
49      // Keep the svuid fixed to prevent deserialization errors. Keep in mind that when adding new properties they will be deserialized to null!
50      private static final long serialVersionUID = 2699497852929596651L;
51  
52      private String uri;
53      private String serverName;
54      private String channel;
55      private String locale;
56      private Map<String, String> params;
57      private Boolean isSecure;
58  
59      /**
60       * @deprecated since 4.4.6 use info.magnolia.module.cache.DefaultCacheKey.DefaultCacheKey(String, String, String, Map<String, String>, Boolean)
61       */
62      @Deprecated
63      public DefaultCacheKey(String uri, String serverName, String locale, Map<String, String> params) {
64          this.uri = uri;
65          this.serverName = serverName;
66          this.locale = locale;
67          this.params = params == null ? null : Collections.unmodifiableMap(params);
68          this.isSecure = false;
69      }
70  
71      public DefaultCacheKey(String uri, String serverName, String locale, String channel, Map<String, String> params, Boolean isSecure){
72          this.uri = uri;
73          this.serverName = serverName;
74          this.channel = channel;
75          this.locale = locale;
76          this.params = params == null ? null : Collections.unmodifiableMap(params);
77          this.isSecure = isSecure;
78      }
79  
80      @Override
81      public int hashCode() {
82          return (uri == null ? 13 : uri.hashCode())
83              + (serverName == null ? 17 : serverName.hashCode())
84              + (locale == null ? 23 : locale.hashCode())
85              + (channel == null ? 25 : channel.hashCode())
86              + (params == null ? 29 :  params.hashCode())
87              + (isSecure == null ? 31 : isSecure.hashCode());
88      }
89  
90      @Override
91      public boolean equals(Object obj) {
92          if (this == obj) {
93              return true;
94          }
95          if (obj == null || !(obj instanceof DefaultCacheKey)) {
96              return false;
97          }
98          DefaultCacheKey that = (DefaultCacheKey) obj;
99          return (this.uri == null) ? that.uri == null : this.uri.equals(that.uri)
100             && (this.serverName == null ? that.serverName == null : this.serverName.equals(that.serverName))
101             && (this.locale == null ? that.locale == null : this.locale.equals(that.locale))
102             && (this.channel == null ? that.channel == null : this.channel.equals(that.channel))
103             && (this.params == null ? that.params == null : this.params.equals(that.params))
104             && (this.isSecure == null ? that.isSecure == null : this.isSecure.equals(that.isSecure));
105     }
106 
107     public String getUri() {
108         return uri;
109     }
110 
111     public String getDomain() {
112         return serverName;
113     }
114 
115     public String getLocale() {
116         return locale;
117     }
118 
119     public String getChannel() {
120         return channel;
121     }
122 
123     public Map<String, String> getParams() {
124         return params;
125     }
126 
127     public Boolean getIsSecured(){
128         return this.isSecure;
129     }
130 
131     // generated toString() method
132     @Override
133     public String toString() {
134         return "DefaultCacheKey{" +
135                 "uri='" + uri + '\'' +
136                 ", serverName='" + serverName + '\'' +
137                 ", locale='" + locale + '\'' +
138                 ", channel='" + channel + '\'' +
139                 ", params=" + params + '\'' +
140                 ", secure='" + isSecure + "'" +
141                 '}';
142     }
143 
144 }