1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16 package org.acegisecurity.acl.basic.cache;
17
18 import org.acegisecurity.acl.basic.AclObjectIdentity;
19 import org.acegisecurity.acl.basic.BasicAclEntry;
20 import org.acegisecurity.acl.basic.BasicAclEntryCache;
21
22 import net.sf.ehcache.Cache;
23 import net.sf.ehcache.CacheException;
24 import net.sf.ehcache.Element;
25
26 import org.apache.commons.logging.Log;
27 import org.apache.commons.logging.LogFactory;
28
29 import org.springframework.beans.factory.InitializingBean;
30
31 import org.springframework.dao.DataRetrievalFailureException;
32 import org.springframework.util.Assert;
33
34
35 /***
36 * Caches <code>BasicAclEntry</code>s using a Spring IoC defined <A
37 * HREF="http://ehcache.sourceforge.net">EHCACHE</a>.
38 *
39 * @author Ben Alex
40 * @version $Id: EhCacheBasedAclEntryCache.java,v 1.5 2005/11/17 00:56:47 benalex Exp $
41 */
42 public class EhCacheBasedAclEntryCache implements BasicAclEntryCache,
43 InitializingBean {
44
45
46 private static final Log logger = LogFactory.getLog(EhCacheBasedAclEntryCache.class);
47
48
49
50 private Cache cache;
51
52
53
54 public void setCache(Cache cache) {
55 this.cache = cache;
56 }
57
58 public Cache getCache() {
59 return cache;
60 }
61
62 public BasicAclEntry[] getEntriesFromCache(
63 AclObjectIdentity aclObjectIdentity) {
64 Element element = null;
65
66 try {
67 element = cache.get(aclObjectIdentity);
68 } catch (CacheException cacheException) {
69 throw new DataRetrievalFailureException("Cache failure: "
70 + cacheException.getMessage());
71 }
72
73
74 if (element == null) {
75 if (logger.isDebugEnabled()) {
76 logger.debug("Cache miss: " + aclObjectIdentity);
77 }
78
79 return null;
80 }
81
82 if (logger.isDebugEnabled()) {
83 logger.debug("Cache hit: " + (element != null) + "; object: "
84 + aclObjectIdentity);
85 }
86
87 BasicAclEntryHolder holder = (BasicAclEntryHolder) element.getValue();
88
89 return holder.getBasicAclEntries();
90 }
91
92 public void afterPropertiesSet() throws Exception {
93 Assert.notNull(cache, "cache mandatory");
94 }
95
96 public void putEntriesInCache(BasicAclEntry[] basicAclEntry) {
97 BasicAclEntryHolder holder = new BasicAclEntryHolder(basicAclEntry);
98 Element element = new Element(basicAclEntry[0].getAclObjectIdentity(),
99 holder);
100
101 if (logger.isDebugEnabled()) {
102 logger.debug("Cache put: " + element.getKey());
103 }
104
105 cache.put(element);
106 }
107 }