org.infinispan.jcache.annotation.AbstractCachePutInterceptor Maven / Gradle / Ivy
package org.infinispan.jcache.annotation;
import java.io.Serializable;
import javax.cache.Cache;
import javax.cache.annotation.CacheKeyGenerator;
import javax.cache.annotation.CacheKeyInvocationContext;
import javax.cache.annotation.CachePut;
import javax.cache.annotation.CacheResolver;
import javax.cache.annotation.GeneratedCacheKey;
import javax.interceptor.InvocationContext;
import org.infinispan.jcache.logging.Log;
/**
* Base {@link javax.cache.annotation.CachePut} interceptor implementation.
*
* @author Kevin Pollet (C) 2011 SERLI
* @author Galder Zamarreño
*/
public abstract class AbstractCachePutInterceptor implements Serializable {
private final boolean trace = getLog().isTraceEnabled();
private final CacheResolver cacheResolver;
private final CacheKeyInvocationContextFactory contextFactory;
public AbstractCachePutInterceptor(CacheResolver cacheResolver, CacheKeyInvocationContextFactory contextFactory) {
this.cacheResolver = cacheResolver;
this.contextFactory = contextFactory;
}
public Object cachePut(InvocationContext invocationContext) throws Exception {
if (trace) {
getLog().tracef("Interception of method named '%s'", invocationContext.getMethod().getName());
}
final CacheKeyInvocationContext cacheKeyInvocationContext = contextFactory.getCacheKeyInvocationContext(invocationContext);
final CacheKeyGenerator cacheKeyGenerator = cacheKeyInvocationContext.unwrap(CacheKeyInvocationContextImpl.class).getCacheKeyGenerator();
final CachePut cachePut = cacheKeyInvocationContext.getCacheAnnotation();
final GeneratedCacheKey cacheKey = cacheKeyGenerator.generateCacheKey(cacheKeyInvocationContext);
final Cache cache = cacheResolver.resolveCache(cacheKeyInvocationContext);
final Object valueToCache = cacheKeyInvocationContext.getValueParameter().getValue();
if (!cachePut.afterInvocation() && valueToCache != null) {
cache.put(cacheKey, valueToCache);
if (trace) {
getLog().tracef("Value '%s' cached in cache '%s' with key '%s' before method invocation", valueToCache, cache.getName(), cacheKey);
}
}
final Object result = invocationContext.proceed();
if (cachePut.afterInvocation() && valueToCache != null) {
cache.put(cacheKey, valueToCache);
if (trace) {
getLog().tracef("Value '%s' cached in cache '%s' with key '%s' after method invocation", valueToCache, cache.getName(), cacheKey);
}
}
return result;
}
protected abstract Log getLog();
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy