kr.pe.kwonnam.hibernate4memcached.strategies.ReadOnlyNaturalIdRegionAccessStrategy Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of hibernate4-memcached-core Show documentation
Show all versions of hibernate4-memcached-core Show documentation
hibernate4 memcached L2 cache implementation.
package kr.pe.kwonnam.hibernate4memcached.strategies;
import kr.pe.kwonnam.hibernate4memcached.regions.NaturalIdMemcachedRegion;
import org.hibernate.cache.CacheException;
import org.hibernate.cache.spi.access.SoftLock;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
/**
* @author KwonNam Son ([email protected])
* @see org.hibernate.cache.spi.access.EntityRegionAccessStrategy
*/
public class ReadOnlyNaturalIdRegionAccessStrategy extends BaseNaturalIdMemcachedRegionAccessStrategy {
private Logger log = LoggerFactory.getLogger(ReadOnlyNaturalIdRegionAccessStrategy.class);
public ReadOnlyNaturalIdRegionAccessStrategy(NaturalIdMemcachedRegion naturalIdMemcachedRegion) {
super(naturalIdMemcachedRegion);
}
@Override
public boolean insert(Object key, Object value) throws CacheException {
log.debug("region access strategy readonly naturalId insert() {} {}", getInternalRegion().getCacheNamespace(), key);
// On read-only, Hibernate never calls this method.
return false;
}
@Override
public boolean afterInsert(Object key, Object value) throws CacheException {
log.debug("region access strategy readonly naturalId afterInsert() {} {}", getInternalRegion().getCacheNamespace(), key);
// On read-only, Hibernate never calls this method.
return false;
}
@Override
public boolean update(Object key, Object value) throws CacheException {
log.debug("region access strategy readonly naturalId update() {} {}", getInternalRegion().getCacheNamespace(), key);
// protect from users' update operation
throw new UnsupportedOperationException("ReadOnly strategy does not support update.");
}
@Override
public boolean afterUpdate(Object key, Object value, SoftLock lock) throws CacheException {
log.debug("region access strategy readonly naturalId afterUpdate() {} {}", getInternalRegion().getCacheNamespace(), key);
// protect from users' update operation
throw new UnsupportedOperationException("ReadOnly strategy does not support update.");
}
}