HHH-10287 - Cache keys no longer include the entity type
This commit is contained in:
parent
d2c91c36d0
commit
1ed76e801b
|
@ -0,0 +1,14 @@
|
||||||
|
/*
|
||||||
|
* Hibernate, Relational Persistence for Idiomatic Java
|
||||||
|
*
|
||||||
|
* License: GNU Lesser General Public License (LGPL), version 2.1 or later.
|
||||||
|
* See the lgpl.txt file in the root directory or <http://www.gnu.org/licenses/lgpl-2.1.html>.
|
||||||
|
*/
|
||||||
|
package org.hibernate.boot.registry.selector.spi;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @author Steve Ebersole
|
||||||
|
*/
|
||||||
|
public interface StrategyCreator<T> {
|
||||||
|
T create(Class<? extends T> strategyClass);
|
||||||
|
}
|
|
@ -19,6 +19,7 @@ import org.hibernate.SessionFactoryObserver;
|
||||||
import org.hibernate.boot.SchemaAutoTooling;
|
import org.hibernate.boot.SchemaAutoTooling;
|
||||||
import org.hibernate.boot.TempTableDdlTransactionHandling;
|
import org.hibernate.boot.TempTableDdlTransactionHandling;
|
||||||
import org.hibernate.boot.registry.StandardServiceRegistry;
|
import org.hibernate.boot.registry.StandardServiceRegistry;
|
||||||
|
import org.hibernate.cache.spi.CacheKeysFactory;
|
||||||
import org.hibernate.cache.spi.QueryCacheFactory;
|
import org.hibernate.cache.spi.QueryCacheFactory;
|
||||||
import org.hibernate.cfg.BaselineSessionEventsListenerBuilder;
|
import org.hibernate.cfg.BaselineSessionEventsListenerBuilder;
|
||||||
import org.hibernate.context.spi.CurrentTenantIdentifierResolver;
|
import org.hibernate.context.spi.CurrentTenantIdentifierResolver;
|
||||||
|
|
|
@ -9,17 +9,16 @@ package org.hibernate.cache.internal;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
import java.util.Properties;
|
import java.util.Properties;
|
||||||
|
|
||||||
import org.hibernate.HibernateException;
|
|
||||||
import org.hibernate.boot.registry.StandardServiceInitiator;
|
import org.hibernate.boot.registry.StandardServiceInitiator;
|
||||||
|
import org.hibernate.boot.registry.selector.spi.StrategySelectionException;
|
||||||
import org.hibernate.boot.registry.selector.spi.StrategySelector;
|
import org.hibernate.boot.registry.selector.spi.StrategySelector;
|
||||||
import org.hibernate.cache.spi.RegionFactory;
|
import org.hibernate.cache.spi.RegionFactory;
|
||||||
import org.hibernate.cfg.AvailableSettings;
|
import org.hibernate.cfg.AvailableSettings;
|
||||||
|
import org.hibernate.internal.CoreLogging;
|
||||||
import org.hibernate.internal.CoreMessageLogger;
|
import org.hibernate.internal.CoreMessageLogger;
|
||||||
import org.hibernate.internal.util.config.ConfigurationHelper;
|
import org.hibernate.internal.util.config.ConfigurationHelper;
|
||||||
import org.hibernate.service.spi.ServiceRegistryImplementor;
|
import org.hibernate.service.spi.ServiceRegistryImplementor;
|
||||||
|
|
||||||
import org.jboss.logging.Logger;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Initiator for the {@link RegionFactory} service.
|
* Initiator for the {@link RegionFactory} service.
|
||||||
*
|
*
|
||||||
|
@ -27,9 +26,7 @@ import org.jboss.logging.Logger;
|
||||||
* @author Brett Meyer
|
* @author Brett Meyer
|
||||||
*/
|
*/
|
||||||
public class RegionFactoryInitiator implements StandardServiceInitiator<RegionFactory> {
|
public class RegionFactoryInitiator implements StandardServiceInitiator<RegionFactory> {
|
||||||
|
private static final CoreMessageLogger LOG = CoreLogging.messageLogger( RegionFactoryInitiator.class );
|
||||||
private static final CoreMessageLogger LOG = Logger.getMessageLogger( CoreMessageLogger.class,
|
|
||||||
RegionFactoryInitiator.class.getName() );
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Singleton access
|
* Singleton access
|
||||||
|
@ -63,26 +60,15 @@ public class RegionFactoryInitiator implements StandardServiceInitiator<RegionFa
|
||||||
|
|
||||||
// The cache provider is needed when we either have second-level cache enabled
|
// The cache provider is needed when we either have second-level cache enabled
|
||||||
// or query cache enabled. Note that useSecondLevelCache is enabled by default
|
// or query cache enabled. Note that useSecondLevelCache is enabled by default
|
||||||
final String setting = ConfigurationHelper.getString( AvailableSettings.CACHE_REGION_FACTORY,
|
if ( useSecondLevelCache || useQueryCache ) {
|
||||||
configurationValues, null );
|
final Object strategyReference = configurationValues != null
|
||||||
if ( ( useSecondLevelCache || useQueryCache ) && setting != null ) {
|
? configurationValues.get( AvailableSettings.CACHE_REGION_FACTORY )
|
||||||
try {
|
: null;
|
||||||
final Class<? extends RegionFactory> regionFactoryClass = registry.getService( StrategySelector.class )
|
regionFactory = resolveRegionFactory(
|
||||||
.selectStrategyImplementor( RegionFactory.class, setting );
|
registry.getService( StrategySelector.class ),
|
||||||
try {
|
strategyReference,
|
||||||
regionFactory = regionFactoryClass.getConstructor( Properties.class ).newInstance( p );
|
p
|
||||||
}
|
);
|
||||||
catch ( NoSuchMethodException e ) {
|
|
||||||
// no constructor accepting Properties found, try no arg constructor
|
|
||||||
LOG.debugf(
|
|
||||||
"%s did not provide constructor accepting java.util.Properties; attempting no-arg constructor.",
|
|
||||||
regionFactoryClass.getSimpleName() );
|
|
||||||
regionFactory = regionFactoryClass.getConstructor().newInstance();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
catch ( Exception e ) {
|
|
||||||
throw new HibernateException( "could not instantiate RegionFactory [" + setting + "]", e );
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
LOG.debugf( "Cache region factory : %s", regionFactory.getClass().getName() );
|
LOG.debugf( "Cache region factory : %s", regionFactory.getClass().getName() );
|
||||||
|
@ -90,6 +76,43 @@ public class RegionFactoryInitiator implements StandardServiceInitiator<RegionFa
|
||||||
return regionFactory;
|
return regionFactory;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@SuppressWarnings("unchecked")
|
||||||
|
private RegionFactory resolveRegionFactory(
|
||||||
|
StrategySelector strategySelector,
|
||||||
|
Object strategyReference,
|
||||||
|
Properties properties) {
|
||||||
|
|
||||||
|
if ( strategyReference == null || RegionFactory.class.isInstance( strategyReference ) ) {
|
||||||
|
// nothing to create; just let strategySelector resolve the RegionFactory
|
||||||
|
return strategySelector.resolveDefaultableStrategy(
|
||||||
|
RegionFactory.class,
|
||||||
|
strategyReference,
|
||||||
|
NoCachingRegionFactory.INSTANCE
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
final Class<? extends RegionFactory> implementationClass;
|
||||||
|
if ( Class.class.isInstance( strategyReference ) ) {
|
||||||
|
implementationClass = (Class<RegionFactory>) strategyReference;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
implementationClass = strategySelector.selectStrategyImplementor(
|
||||||
|
RegionFactory.class,
|
||||||
|
strategyReference.toString()
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
try {
|
||||||
|
return new StrategyCreatorRegionFactoryImpl( properties ).create( implementationClass );
|
||||||
|
}
|
||||||
|
catch (Exception e) {
|
||||||
|
throw new StrategySelectionException(
|
||||||
|
String.format( "Could not instantiate named strategy class [%s]", implementationClass.getName() ),
|
||||||
|
e
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Map legacy names unto the new corollary.
|
* Map legacy names unto the new corollary.
|
||||||
*
|
*
|
||||||
|
|
83
hibernate-core/src/main/java/org/hibernate/cache/internal/StrategyCreatorRegionFactoryImpl.java
vendored
Normal file
83
hibernate-core/src/main/java/org/hibernate/cache/internal/StrategyCreatorRegionFactoryImpl.java
vendored
Normal file
|
@ -0,0 +1,83 @@
|
||||||
|
/*
|
||||||
|
* Hibernate, Relational Persistence for Idiomatic Java
|
||||||
|
*
|
||||||
|
* License: GNU Lesser General Public License (LGPL), version 2.1 or later.
|
||||||
|
* See the lgpl.txt file in the root directory or <http://www.gnu.org/licenses/lgpl-2.1.html>.
|
||||||
|
*/
|
||||||
|
package org.hibernate.cache.internal;
|
||||||
|
|
||||||
|
import java.lang.reflect.Constructor;
|
||||||
|
import java.lang.reflect.InvocationTargetException;
|
||||||
|
import java.util.Map;
|
||||||
|
import java.util.Properties;
|
||||||
|
|
||||||
|
import org.hibernate.boot.registry.selector.spi.StrategyCreator;
|
||||||
|
import org.hibernate.cache.spi.RegionFactory;
|
||||||
|
import org.hibernate.service.spi.ServiceException;
|
||||||
|
|
||||||
|
import org.jboss.logging.Logger;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @author Steve Ebersole
|
||||||
|
*/
|
||||||
|
public class StrategyCreatorRegionFactoryImpl implements StrategyCreator<RegionFactory> {
|
||||||
|
private static final Logger log = Logger.getLogger( StrategyCreatorRegionFactoryImpl.class );
|
||||||
|
|
||||||
|
private final Properties properties;
|
||||||
|
|
||||||
|
public StrategyCreatorRegionFactoryImpl(Properties properties) {
|
||||||
|
this.properties = properties;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public RegionFactory create(Class<? extends RegionFactory> strategyClass) {
|
||||||
|
assert RegionFactory.class.isAssignableFrom( strategyClass );
|
||||||
|
|
||||||
|
// first look for a constructor accepting Properties
|
||||||
|
try {
|
||||||
|
final Constructor<? extends RegionFactory> ctor = strategyClass.getConstructor( Properties.class );
|
||||||
|
return ctor.newInstance( properties );
|
||||||
|
}
|
||||||
|
catch ( NoSuchMethodException e ) {
|
||||||
|
log.debugf( "RegionFactory impl [%s] did not provide constructor accepting Properties", strategyClass.getName() );
|
||||||
|
}
|
||||||
|
catch ( IllegalAccessException e ) {
|
||||||
|
throw new ServiceException( "Unable to call constructor of RegionFactory impl [" + strategyClass.getName() + "]", e );
|
||||||
|
}
|
||||||
|
catch ( InstantiationException e ) {
|
||||||
|
throw new ServiceException( "Unable to call constructor of RegionFactory impl [" + strategyClass.getName() + "]", e );
|
||||||
|
}
|
||||||
|
catch ( InvocationTargetException e ) {
|
||||||
|
throw new ServiceException( "Unable to call constructor of RegionFactory impl [" + strategyClass.getName() + "]", e );
|
||||||
|
}
|
||||||
|
|
||||||
|
// next try Map
|
||||||
|
try {
|
||||||
|
final Constructor<? extends RegionFactory> ctor = strategyClass.getConstructor( Map.class );
|
||||||
|
return ctor.newInstance( properties );
|
||||||
|
}
|
||||||
|
catch ( NoSuchMethodException e ) {
|
||||||
|
log.debugf( "RegionFactory impl [%s] did not provide constructor accepting Properties", strategyClass.getName() );
|
||||||
|
}
|
||||||
|
catch ( IllegalAccessException e ) {
|
||||||
|
throw new ServiceException( "Unable to call constructor of RegionFactory impl [" + strategyClass.getName() + "]", e );
|
||||||
|
}
|
||||||
|
catch ( InstantiationException e ) {
|
||||||
|
throw new ServiceException( "Unable to call constructor of RegionFactory impl [" + strategyClass.getName() + "]", e );
|
||||||
|
}
|
||||||
|
catch ( InvocationTargetException e ) {
|
||||||
|
throw new ServiceException( "Unable to call constructor of RegionFactory impl [" + strategyClass.getName() + "]", e );
|
||||||
|
}
|
||||||
|
|
||||||
|
// finally try no-arg
|
||||||
|
try {
|
||||||
|
return strategyClass.newInstance();
|
||||||
|
}
|
||||||
|
catch ( IllegalAccessException e ) {
|
||||||
|
throw new ServiceException( "Unable to call constructor of RegionFactory impl [" + strategyClass.getName() + "]", e );
|
||||||
|
}
|
||||||
|
catch ( InstantiationException e ) {
|
||||||
|
throw new ServiceException( "Unable to call constructor of RegionFactory impl [" + strategyClass.getName() + "]", e );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -668,14 +668,31 @@ public interface AvailableSettings {
|
||||||
// ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
// ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The {@link org.hibernate.cache.spi.RegionFactory} implementation class
|
* The {@link org.hibernate.cache.spi.RegionFactory} implementation. Can refer to:<ul>
|
||||||
|
* <li>an Object implementing {@link org.hibernate.cache.spi.RegionFactory}</li>
|
||||||
|
* <li>a Class implementing {@link org.hibernate.cache.spi.RegionFactory}</li>
|
||||||
|
* <li>FQN of a Class implementing {@link org.hibernate.cache.spi.RegionFactory}</li>
|
||||||
|
* </ul>
|
||||||
*/
|
*/
|
||||||
String CACHE_REGION_FACTORY = "hibernate.cache.region.factory_class";
|
String CACHE_REGION_FACTORY = "hibernate.cache.region.factory_class";
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Allow control to specify the {@link org.hibernate.cache.spi.CacheKeysFactory} impl to use.
|
||||||
|
* Can refer to:<ul>
|
||||||
|
* <li>an Object implementing {@link org.hibernate.cache.spi.CacheKeysFactory}</li>
|
||||||
|
* <li>a Class implementing {@link org.hibernate.cache.spi.CacheKeysFactory}</li>
|
||||||
|
* <li>FQN of a Class implementing {@link org.hibernate.cache.spi.CacheKeysFactory}</li>
|
||||||
|
* </ul>
|
||||||
|
*
|
||||||
|
* @since 5.2 - note that currently this is only honored for hibernate-infinispan
|
||||||
|
*/
|
||||||
|
String CACHE_KEYS_FACTORY = "hibernate.cache.keys_factory";
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The <tt>CacheProvider</tt> implementation class
|
* The <tt>CacheProvider</tt> implementation class
|
||||||
*/
|
*/
|
||||||
String CACHE_PROVIDER_CONFIG = "hibernate.cache.provider_configuration_file_resource_path";
|
String CACHE_PROVIDER_CONFIG = "hibernate.cache.provider_configuration_file_resource_path";
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Enable the second-level cache (enabled by default)
|
* Enable the second-level cache (enabled by default)
|
||||||
*/
|
*/
|
||||||
|
|
|
@ -0,0 +1,94 @@
|
||||||
|
/*
|
||||||
|
* Hibernate, Relational Persistence for Idiomatic Java
|
||||||
|
*
|
||||||
|
* License: GNU Lesser General Public License (LGPL), version 2.1 or later.
|
||||||
|
* See the lgpl.txt file in the root directory or <http://www.gnu.org/licenses/lgpl-2.1.html>.
|
||||||
|
*/
|
||||||
|
package org.hibernate.test.cache;
|
||||||
|
|
||||||
|
import java.util.Properties;
|
||||||
|
import javax.persistence.Entity;
|
||||||
|
import javax.persistence.Id;
|
||||||
|
|
||||||
|
import org.hibernate.Session;
|
||||||
|
import org.hibernate.annotations.Cache;
|
||||||
|
import org.hibernate.annotations.CacheConcurrencyStrategy;
|
||||||
|
import org.hibernate.boot.MetadataSources;
|
||||||
|
import org.hibernate.boot.registry.StandardServiceRegistryBuilder;
|
||||||
|
import org.hibernate.boot.spi.SessionFactoryOptions;
|
||||||
|
import org.hibernate.cache.CacheException;
|
||||||
|
import org.hibernate.cache.internal.DefaultCacheKeysFactory;
|
||||||
|
import org.hibernate.cache.internal.SimpleCacheKeysFactory;
|
||||||
|
import org.hibernate.cache.spi.CacheDataDescription;
|
||||||
|
import org.hibernate.cache.spi.EntityRegion;
|
||||||
|
import org.hibernate.cfg.AvailableSettings;
|
||||||
|
|
||||||
|
import org.hibernate.testing.cache.CachingRegionFactory;
|
||||||
|
import org.hibernate.testing.junit4.BaseNonConfigCoreFunctionalTestCase;
|
||||||
|
import org.junit.Test;
|
||||||
|
|
||||||
|
import static org.junit.Assert.assertNull;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @author Steve Ebersole
|
||||||
|
*/
|
||||||
|
public class SharedRegionTest extends BaseNonConfigCoreFunctionalTestCase {
|
||||||
|
@Override
|
||||||
|
protected void configureStandardServiceRegistryBuilder(StandardServiceRegistryBuilder ssrb) {
|
||||||
|
super.configureStandardServiceRegistryBuilder( ssrb );
|
||||||
|
ssrb.applySetting( AvailableSettings.USE_SECOND_LEVEL_CACHE, true );
|
||||||
|
ssrb.applySetting( AvailableSettings.CACHE_REGION_FACTORY, new CachingRegionFactory() );
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void applyMetadataSources(MetadataSources metadataSources) {
|
||||||
|
super.applyMetadataSources( metadataSources );
|
||||||
|
metadataSources.addAnnotatedClass( StateCodes.class );
|
||||||
|
metadataSources.addAnnotatedClass( ZipCodes.class );
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void test() {
|
||||||
|
// create a StateCodes
|
||||||
|
Session s = openSession();
|
||||||
|
s.beginTransaction();
|
||||||
|
s.save( new StateCodes( 1 ) );
|
||||||
|
s.getTransaction().commit();
|
||||||
|
s.close();
|
||||||
|
|
||||||
|
// now try to load a ZipCodes using the same id : should just return null rather than blow up :)
|
||||||
|
s = openSession();
|
||||||
|
s.beginTransaction();
|
||||||
|
ZipCodes zc = s.get( ZipCodes.class, 1 );
|
||||||
|
assertNull( zc );
|
||||||
|
s.getTransaction().commit();
|
||||||
|
s.close();
|
||||||
|
|
||||||
|
s = openSession();
|
||||||
|
s.beginTransaction();
|
||||||
|
s.get( ZipCodes.class, 1 );
|
||||||
|
s.getTransaction().commit();
|
||||||
|
s.close();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Entity( name="StateCodes" )
|
||||||
|
@Cache( region="com.acme.referenceData", usage = CacheConcurrencyStrategy.READ_WRITE )
|
||||||
|
public static class StateCodes {
|
||||||
|
@Id
|
||||||
|
public Integer id;
|
||||||
|
|
||||||
|
public StateCodes() {
|
||||||
|
}
|
||||||
|
|
||||||
|
public StateCodes(Integer id) {
|
||||||
|
this.id = id;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Entity( name = "ZipCodes" )
|
||||||
|
@Cache( region="com.acme.referenceData", usage = CacheConcurrencyStrategy.READ_WRITE )
|
||||||
|
public static class ZipCodes {
|
||||||
|
@Id
|
||||||
|
public Integer id;
|
||||||
|
}
|
||||||
|
}
|
|
@ -21,6 +21,7 @@ import java.util.concurrent.TimeUnit;
|
||||||
|
|
||||||
import org.hibernate.boot.registry.classloading.spi.ClassLoaderService;
|
import org.hibernate.boot.registry.classloading.spi.ClassLoaderService;
|
||||||
import org.hibernate.MultiTenancyStrategy;
|
import org.hibernate.MultiTenancyStrategy;
|
||||||
|
import org.hibernate.boot.registry.selector.spi.StrategySelector;
|
||||||
import org.hibernate.boot.spi.SessionFactoryOptions;
|
import org.hibernate.boot.spi.SessionFactoryOptions;
|
||||||
import org.hibernate.cache.CacheException;
|
import org.hibernate.cache.CacheException;
|
||||||
import org.hibernate.cache.infinispan.collection.CollectionRegionImpl;
|
import org.hibernate.cache.infinispan.collection.CollectionRegionImpl;
|
||||||
|
@ -45,6 +46,7 @@ import org.hibernate.cache.spi.QueryResultsRegion;
|
||||||
import org.hibernate.cache.spi.RegionFactory;
|
import org.hibernate.cache.spi.RegionFactory;
|
||||||
import org.hibernate.cache.spi.TimestampsRegion;
|
import org.hibernate.cache.spi.TimestampsRegion;
|
||||||
import org.hibernate.cache.spi.access.AccessType;
|
import org.hibernate.cache.spi.access.AccessType;
|
||||||
|
import org.hibernate.cfg.AvailableSettings;
|
||||||
import org.hibernate.internal.util.config.ConfigurationHelper;
|
import org.hibernate.internal.util.config.ConfigurationHelper;
|
||||||
import org.hibernate.service.ServiceRegistry;
|
import org.hibernate.service.ServiceRegistry;
|
||||||
|
|
||||||
|
@ -229,6 +231,7 @@ public class InfinispanRegionFactory implements RegionFactory {
|
||||||
|
|
||||||
private Configuration pendingPutsCacheConfiguration;
|
private Configuration pendingPutsCacheConfiguration;
|
||||||
|
|
||||||
|
private CacheKeysFactory cacheKeysFactory;
|
||||||
private EmbeddedCacheManager manager;
|
private EmbeddedCacheManager manager;
|
||||||
|
|
||||||
private final Map<String, TypeOverrides> typeOverrides = new HashMap<String, TypeOverrides>();
|
private final Map<String, TypeOverrides> typeOverrides = new HashMap<String, TypeOverrides>();
|
||||||
|
@ -257,6 +260,7 @@ public class InfinispanRegionFactory implements RegionFactory {
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@SuppressWarnings("unchecked")
|
||||||
public CollectionRegion buildCollectionRegion(
|
public CollectionRegion buildCollectionRegion(
|
||||||
String regionName,
|
String regionName,
|
||||||
Properties properties,
|
Properties properties,
|
||||||
|
@ -265,7 +269,7 @@ public class InfinispanRegionFactory implements RegionFactory {
|
||||||
log.debug( "Building collection cache region [" + regionName + "]" );
|
log.debug( "Building collection cache region [" + regionName + "]" );
|
||||||
}
|
}
|
||||||
final AdvancedCache cache = getCache( regionName, COLLECTION_KEY, properties, metadata);
|
final AdvancedCache cache = getCache( regionName, COLLECTION_KEY, properties, metadata);
|
||||||
final CollectionRegionImpl region = new CollectionRegionImpl( cache, regionName, transactionManager, metadata, this, buildCacheKeysFactory() );
|
final CollectionRegionImpl region = new CollectionRegionImpl( cache, regionName, transactionManager, metadata, this, getCacheKeysFactory() );
|
||||||
startRegion( region );
|
startRegion( region );
|
||||||
return region;
|
return region;
|
||||||
}
|
}
|
||||||
|
@ -282,7 +286,7 @@ public class InfinispanRegionFactory implements RegionFactory {
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
final AdvancedCache cache = getCache( regionName, metadata.isMutable() ? ENTITY_KEY : IMMUTABLE_ENTITY_KEY, properties, metadata );
|
final AdvancedCache cache = getCache( regionName, metadata.isMutable() ? ENTITY_KEY : IMMUTABLE_ENTITY_KEY, properties, metadata );
|
||||||
final EntityRegionImpl region = new EntityRegionImpl( cache, regionName, transactionManager, metadata, this, buildCacheKeysFactory() );
|
final EntityRegionImpl region = new EntityRegionImpl( cache, regionName, transactionManager, metadata, this, getCacheKeysFactory() );
|
||||||
startRegion( region );
|
startRegion( region );
|
||||||
return region;
|
return region;
|
||||||
}
|
}
|
||||||
|
@ -294,7 +298,7 @@ public class InfinispanRegionFactory implements RegionFactory {
|
||||||
log.debug("Building natural id cache region [" + regionName + "]");
|
log.debug("Building natural id cache region [" + regionName + "]");
|
||||||
}
|
}
|
||||||
final AdvancedCache cache = getCache( regionName, NATURAL_ID_KEY, properties, metadata);
|
final AdvancedCache cache = getCache( regionName, NATURAL_ID_KEY, properties, metadata);
|
||||||
final NaturalIdRegionImpl region = new NaturalIdRegionImpl( cache, regionName, transactionManager, metadata, this, buildCacheKeysFactory());
|
final NaturalIdRegionImpl region = new NaturalIdRegionImpl( cache, regionName, transactionManager, metadata, this, getCacheKeysFactory());
|
||||||
startRegion( region );
|
startRegion( region );
|
||||||
return region;
|
return region;
|
||||||
}
|
}
|
||||||
|
@ -318,8 +322,8 @@ public class InfinispanRegionFactory implements RegionFactory {
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public TimestampsRegion buildTimestampsRegion(String regionName, Properties properties)
|
@SuppressWarnings("unchecked")
|
||||||
throws CacheException {
|
public TimestampsRegion buildTimestampsRegion(String regionName, Properties properties) {
|
||||||
if ( log.isDebugEnabled() ) {
|
if ( log.isDebugEnabled() ) {
|
||||||
log.debug( "Building timestamps cache region [" + regionName + "]" );
|
log.debug( "Building timestamps cache region [" + regionName + "]" );
|
||||||
}
|
}
|
||||||
|
@ -339,13 +343,8 @@ public class InfinispanRegionFactory implements RegionFactory {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private CacheKeysFactory buildCacheKeysFactory() {
|
private CacheKeysFactory getCacheKeysFactory() {
|
||||||
if (settings.getMultiTenancyStrategy() != MultiTenancyStrategy.NONE) {
|
return cacheKeysFactory;
|
||||||
return DefaultCacheKeysFactory.INSTANCE;
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
return SimpleCacheKeysFactory.INSTANCE;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -374,6 +373,10 @@ public class InfinispanRegionFactory implements RegionFactory {
|
||||||
@Override
|
@Override
|
||||||
public void start(SessionFactoryOptions settings, Properties properties) throws CacheException {
|
public void start(SessionFactoryOptions settings, Properties properties) throws CacheException {
|
||||||
log.debug( "Starting Infinispan region factory" );
|
log.debug( "Starting Infinispan region factory" );
|
||||||
|
|
||||||
|
// determine the CacheKeysFactory to use...
|
||||||
|
this.cacheKeysFactory = determineCacheKeysFactory( settings, properties );
|
||||||
|
|
||||||
try {
|
try {
|
||||||
transactionManagerlookup = createTransactionManagerLookup( settings, properties );
|
transactionManagerlookup = createTransactionManagerLookup( settings, properties );
|
||||||
transactionManager = transactionManagerlookup.getTransactionManager();
|
transactionManager = transactionManagerlookup.getTransactionManager();
|
||||||
|
@ -416,6 +419,18 @@ public class InfinispanRegionFactory implements RegionFactory {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private CacheKeysFactory determineCacheKeysFactory(SessionFactoryOptions settings, Properties properties) {
|
||||||
|
final CacheKeysFactory implicitFactory = settings.getMultiTenancyStrategy() != MultiTenancyStrategy.NONE
|
||||||
|
? DefaultCacheKeysFactory.INSTANCE
|
||||||
|
: SimpleCacheKeysFactory.INSTANCE;
|
||||||
|
|
||||||
|
return settings.getServiceRegistry().getService( StrategySelector.class ).resolveDefaultableStrategy(
|
||||||
|
CacheKeysFactory.class,
|
||||||
|
properties.get( AvailableSettings.CACHE_KEYS_FACTORY ),
|
||||||
|
implicitFactory
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
protected org.infinispan.transaction.lookup.TransactionManagerLookup createTransactionManagerLookup(
|
protected org.infinispan.transaction.lookup.TransactionManagerLookup createTransactionManagerLookup(
|
||||||
SessionFactoryOptions settings, Properties properties) {
|
SessionFactoryOptions settings, Properties properties) {
|
||||||
return new HibernateTransactionManagerLookup( settings, properties );
|
return new HibernateTransactionManagerLookup( settings, properties );
|
||||||
|
|
|
@ -6,7 +6,6 @@
|
||||||
*/
|
*/
|
||||||
package org.hibernate.testing.cache;
|
package org.hibernate.testing.cache;
|
||||||
|
|
||||||
import org.hibernate.cache.internal.DefaultCacheKeysFactory;
|
|
||||||
import org.hibernate.cache.spi.CollectionRegion;
|
import org.hibernate.cache.spi.CollectionRegion;
|
||||||
import org.hibernate.cache.spi.access.CollectionRegionAccessStrategy;
|
import org.hibernate.cache.spi.access.CollectionRegionAccessStrategy;
|
||||||
import org.hibernate.engine.spi.SessionFactoryImplementor;
|
import org.hibernate.engine.spi.SessionFactoryImplementor;
|
||||||
|
@ -40,12 +39,12 @@ class BaseCollectionRegionAccessStrategy extends BaseRegionAccessStrategy implem
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Object generateCacheKey(Object id, CollectionPersister persister, SessionFactoryImplementor factory, String tenantIdentifier) {
|
public Object generateCacheKey(Object id, CollectionPersister persister, SessionFactoryImplementor factory, String tenantIdentifier) {
|
||||||
return DefaultCacheKeysFactory.createCollectionKey( id, persister, factory, tenantIdentifier );
|
return region.getRegionFactory().getCacheKeysFactory().createCollectionKey( id, persister, factory, tenantIdentifier );
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Object getCacheKeyId(Object cacheKey) {
|
public Object getCacheKeyId(Object cacheKey) {
|
||||||
return DefaultCacheKeysFactory.getCollectionId(cacheKey);
|
return region.getRegionFactory().getCacheKeysFactory().getCollectionId( cacheKey );
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -7,7 +7,6 @@
|
||||||
package org.hibernate.testing.cache;
|
package org.hibernate.testing.cache;
|
||||||
|
|
||||||
import org.hibernate.cache.CacheException;
|
import org.hibernate.cache.CacheException;
|
||||||
import org.hibernate.cache.internal.DefaultCacheKeysFactory;
|
|
||||||
import org.hibernate.cache.spi.EntityRegion;
|
import org.hibernate.cache.spi.EntityRegion;
|
||||||
import org.hibernate.cache.spi.access.EntityRegionAccessStrategy;
|
import org.hibernate.cache.spi.access.EntityRegionAccessStrategy;
|
||||||
import org.hibernate.cache.spi.access.SoftLock;
|
import org.hibernate.cache.spi.access.SoftLock;
|
||||||
|
@ -65,11 +64,11 @@ class BaseEntityRegionAccessStrategy extends BaseRegionAccessStrategy implements
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Object generateCacheKey(Object id, EntityPersister persister, SessionFactoryImplementor factory, String tenantIdentifier) {
|
public Object generateCacheKey(Object id, EntityPersister persister, SessionFactoryImplementor factory, String tenantIdentifier) {
|
||||||
return DefaultCacheKeysFactory.createEntityKey( id, persister, factory, tenantIdentifier );
|
return region.getRegionFactory().getCacheKeysFactory().createEntityKey( id, persister, factory, tenantIdentifier );
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Object getCacheKeyId(Object cacheKey) {
|
public Object getCacheKeyId(Object cacheKey) {
|
||||||
return DefaultCacheKeysFactory.getEntityId(cacheKey);
|
return region.getRegionFactory().getCacheKeysFactory().getEntityId( cacheKey );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -18,8 +18,8 @@ import org.jboss.logging.Logger;
|
||||||
class BaseGeneralDataRegion extends BaseRegion implements GeneralDataRegion {
|
class BaseGeneralDataRegion extends BaseRegion implements GeneralDataRegion {
|
||||||
private static final Logger LOG = Logger.getLogger( BaseGeneralDataRegion.class.getName() );
|
private static final Logger LOG = Logger.getLogger( BaseGeneralDataRegion.class.getName() );
|
||||||
|
|
||||||
BaseGeneralDataRegion(String name) {
|
BaseGeneralDataRegion(CachingRegionFactory cachingRegionFactory, String name) {
|
||||||
super( name );
|
super( cachingRegionFactory, name );
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
|
@ -7,7 +7,6 @@
|
||||||
package org.hibernate.testing.cache;
|
package org.hibernate.testing.cache;
|
||||||
|
|
||||||
import org.hibernate.cache.CacheException;
|
import org.hibernate.cache.CacheException;
|
||||||
import org.hibernate.cache.internal.DefaultCacheKeysFactory;
|
|
||||||
import org.hibernate.cache.spi.NaturalIdRegion;
|
import org.hibernate.cache.spi.NaturalIdRegion;
|
||||||
import org.hibernate.cache.spi.access.NaturalIdRegionAccessStrategy;
|
import org.hibernate.cache.spi.access.NaturalIdRegionAccessStrategy;
|
||||||
import org.hibernate.cache.spi.access.SoftLock;
|
import org.hibernate.cache.spi.access.SoftLock;
|
||||||
|
@ -61,11 +60,11 @@ class BaseNaturalIdRegionAccessStrategy extends BaseRegionAccessStrategy impleme
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Object generateCacheKey(Object[] naturalIdValues, EntityPersister persister, SessionImplementor session) {
|
public Object generateCacheKey(Object[] naturalIdValues, EntityPersister persister, SessionImplementor session) {
|
||||||
return DefaultCacheKeysFactory.createNaturalIdKey( naturalIdValues, persister, session );
|
return region.getRegionFactory().getCacheKeysFactory().createNaturalIdKey( naturalIdValues, persister, session );
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Object[] getNaturalIdValues(Object cacheKey) {
|
public Object[] getNaturalIdValues(Object cacheKey) {
|
||||||
return DefaultCacheKeysFactory.getNaturalIdValues( cacheKey );
|
return region.getRegionFactory().getCacheKeysFactory().getNaturalIdValues( cacheKey );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -17,11 +17,14 @@ import org.hibernate.cache.spi.Region;
|
||||||
* @author Strong Liu
|
* @author Strong Liu
|
||||||
*/
|
*/
|
||||||
class BaseRegion implements Region {
|
class BaseRegion implements Region {
|
||||||
protected final Map cache = new ConcurrentHashMap();
|
private final CachingRegionFactory cachingRegionFactory;
|
||||||
private final String name;
|
private final String name;
|
||||||
|
protected final Map cache = new ConcurrentHashMap();
|
||||||
|
|
||||||
private static int timeout = Timestamper.ONE_MS * 60000; //60s
|
private static int timeout = Timestamper.ONE_MS * 60000; //60s
|
||||||
|
|
||||||
BaseRegion(String name) {
|
BaseRegion(CachingRegionFactory cachingRegionFactory, String name) {
|
||||||
|
this.cachingRegionFactory = cachingRegionFactory;
|
||||||
this.name = name;
|
this.name = name;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -30,6 +33,10 @@ class BaseRegion implements Region {
|
||||||
return key != null ? cache.containsKey( key ) : false;
|
return key != null ? cache.containsKey( key ) : false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public CachingRegionFactory getRegionFactory() {
|
||||||
|
return cachingRegionFactory;
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String getName() {
|
public String getName() {
|
||||||
return name;
|
return name;
|
||||||
|
|
|
@ -15,8 +15,8 @@ import org.hibernate.cache.spi.TransactionalDataRegion;
|
||||||
class BaseTransactionalDataRegion extends BaseGeneralDataRegion implements TransactionalDataRegion {
|
class BaseTransactionalDataRegion extends BaseGeneralDataRegion implements TransactionalDataRegion {
|
||||||
private final CacheDataDescription metadata;
|
private final CacheDataDescription metadata;
|
||||||
|
|
||||||
BaseTransactionalDataRegion(String name, CacheDataDescription metadata) {
|
BaseTransactionalDataRegion(CachingRegionFactory cachingRegionFactory, String name, CacheDataDescription metadata) {
|
||||||
super( name );
|
super( cachingRegionFactory, name );
|
||||||
this.metadata = metadata;
|
this.metadata = metadata;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -10,7 +10,9 @@ import java.util.Properties;
|
||||||
|
|
||||||
import org.hibernate.boot.spi.SessionFactoryOptions;
|
import org.hibernate.boot.spi.SessionFactoryOptions;
|
||||||
import org.hibernate.cache.CacheException;
|
import org.hibernate.cache.CacheException;
|
||||||
|
import org.hibernate.cache.internal.DefaultCacheKeysFactory;
|
||||||
import org.hibernate.cache.spi.CacheDataDescription;
|
import org.hibernate.cache.spi.CacheDataDescription;
|
||||||
|
import org.hibernate.cache.spi.CacheKeysFactory;
|
||||||
import org.hibernate.cache.spi.CollectionRegion;
|
import org.hibernate.cache.spi.CollectionRegion;
|
||||||
import org.hibernate.cache.spi.EntityRegion;
|
import org.hibernate.cache.spi.EntityRegion;
|
||||||
import org.hibernate.cache.spi.NaturalIdRegion;
|
import org.hibernate.cache.spi.NaturalIdRegion;
|
||||||
|
@ -28,19 +30,34 @@ public class CachingRegionFactory implements RegionFactory {
|
||||||
private static final Logger LOG = Logger.getLogger( CachingRegionFactory.class.getName() );
|
private static final Logger LOG = Logger.getLogger( CachingRegionFactory.class.getName() );
|
||||||
|
|
||||||
public static String DEFAULT_ACCESSTYPE = "DefaultAccessType";
|
public static String DEFAULT_ACCESSTYPE = "DefaultAccessType";
|
||||||
|
|
||||||
|
private final CacheKeysFactory cacheKeysFactory;
|
||||||
|
|
||||||
private SessionFactoryOptions settings;
|
private SessionFactoryOptions settings;
|
||||||
private Properties properties;
|
private Properties properties;
|
||||||
|
|
||||||
public CachingRegionFactory() {
|
public CachingRegionFactory() {
|
||||||
LOG.warn( "CachingRegionFactory should be only used for testing." );
|
this( DefaultCacheKeysFactory.INSTANCE, null );
|
||||||
|
}
|
||||||
|
|
||||||
|
public CachingRegionFactory(CacheKeysFactory cacheKeysFactory) {
|
||||||
|
this( cacheKeysFactory, null );
|
||||||
}
|
}
|
||||||
|
|
||||||
public CachingRegionFactory(Properties properties) {
|
public CachingRegionFactory(Properties properties) {
|
||||||
//add here to avoid run into catch
|
this( DefaultCacheKeysFactory.INSTANCE, properties );
|
||||||
|
}
|
||||||
|
|
||||||
|
public CachingRegionFactory(CacheKeysFactory cacheKeysFactory, Properties properties) {
|
||||||
LOG.warn( "CachingRegionFactory should be only used for testing." );
|
LOG.warn( "CachingRegionFactory should be only used for testing." );
|
||||||
|
this.cacheKeysFactory = cacheKeysFactory;
|
||||||
this.properties = properties;
|
this.properties = properties;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public CacheKeysFactory getCacheKeysFactory() {
|
||||||
|
return cacheKeysFactory;
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void start(SessionFactoryOptions settings, Properties properties) throws CacheException {
|
public void start(SessionFactoryOptions settings, Properties properties) throws CacheException {
|
||||||
this.settings = settings;
|
this.settings = settings;
|
||||||
|
@ -72,43 +89,42 @@ public class CachingRegionFactory implements RegionFactory {
|
||||||
@Override
|
@Override
|
||||||
public EntityRegion buildEntityRegion(String regionName, Properties properties, CacheDataDescription metadata)
|
public EntityRegion buildEntityRegion(String regionName, Properties properties, CacheDataDescription metadata)
|
||||||
throws CacheException {
|
throws CacheException {
|
||||||
return new EntityRegionImpl( regionName, metadata, settings );
|
return new EntityRegionImpl( this, regionName, metadata, settings );
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public NaturalIdRegion buildNaturalIdRegion(String regionName, Properties properties, CacheDataDescription metadata)
|
public NaturalIdRegion buildNaturalIdRegion(String regionName, Properties properties, CacheDataDescription metadata)
|
||||||
throws CacheException {
|
throws CacheException {
|
||||||
return new NaturalIdRegionImpl( regionName, metadata, settings );
|
return new NaturalIdRegionImpl( this, regionName, metadata, settings );
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public CollectionRegion buildCollectionRegion(
|
public CollectionRegion buildCollectionRegion(
|
||||||
String regionName,
|
String regionName,
|
||||||
Properties properties,
|
Properties properties,
|
||||||
CacheDataDescription metadata)
|
CacheDataDescription metadata) throws CacheException {
|
||||||
throws CacheException {
|
return new CollectionRegionImpl( this, regionName, metadata, settings );
|
||||||
return new CollectionRegionImpl( regionName, metadata, settings );
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public QueryResultsRegion buildQueryResultsRegion(String regionName, Properties properties) throws CacheException {
|
public QueryResultsRegion buildQueryResultsRegion(String regionName, Properties properties) throws CacheException {
|
||||||
return new QueryResultsRegionImpl( regionName );
|
return new QueryResultsRegionImpl( this, regionName );
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public TimestampsRegion buildTimestampsRegion(String regionName, Properties properties) throws CacheException {
|
public TimestampsRegion buildTimestampsRegion(String regionName, Properties properties) throws CacheException {
|
||||||
return new TimestampsRegionImpl( regionName );
|
return new TimestampsRegionImpl( this, regionName );
|
||||||
}
|
}
|
||||||
|
|
||||||
private static class QueryResultsRegionImpl extends BaseGeneralDataRegion implements QueryResultsRegion {
|
private static class QueryResultsRegionImpl extends BaseGeneralDataRegion implements QueryResultsRegion {
|
||||||
QueryResultsRegionImpl(String name) {
|
QueryResultsRegionImpl(CachingRegionFactory cachingRegionFactory, String name) {
|
||||||
super( name );
|
super( cachingRegionFactory, name );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private static class TimestampsRegionImpl extends BaseGeneralDataRegion implements TimestampsRegion {
|
private static class TimestampsRegionImpl extends BaseGeneralDataRegion implements TimestampsRegion {
|
||||||
TimestampsRegionImpl(String name) {
|
TimestampsRegionImpl(CachingRegionFactory cachingRegionFactory, String name) {
|
||||||
super( name );
|
super( cachingRegionFactory, name );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -23,8 +23,12 @@ class CollectionRegionImpl extends BaseTransactionalDataRegion implements Collec
|
||||||
|
|
||||||
private final SessionFactoryOptions settings;
|
private final SessionFactoryOptions settings;
|
||||||
|
|
||||||
CollectionRegionImpl(String name, CacheDataDescription metadata, SessionFactoryOptions settings) {
|
CollectionRegionImpl(
|
||||||
super( name, metadata );
|
CachingRegionFactory cachingRegionFactory,
|
||||||
|
String name,
|
||||||
|
CacheDataDescription metadata,
|
||||||
|
SessionFactoryOptions settings) {
|
||||||
|
super( cachingRegionFactory, name, metadata );
|
||||||
this.settings = settings;
|
this.settings = settings;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -18,14 +18,17 @@ import org.jboss.logging.Logger;
|
||||||
/**
|
/**
|
||||||
* @author Strong Liu
|
* @author Strong Liu
|
||||||
*/
|
*/
|
||||||
class EntityRegionImpl extends BaseTransactionalDataRegion implements EntityRegion {
|
public class EntityRegionImpl extends BaseTransactionalDataRegion implements EntityRegion {
|
||||||
private static final Logger LOG = Logger.getLogger( EntityRegionImpl.class );
|
private static final Logger LOG = Logger.getLogger( EntityRegionImpl.class );
|
||||||
|
|
||||||
|
|
||||||
private final SessionFactoryOptions settings;
|
private final SessionFactoryOptions settings;
|
||||||
|
|
||||||
EntityRegionImpl(String name, CacheDataDescription metadata, SessionFactoryOptions settings) {
|
protected EntityRegionImpl(
|
||||||
super( name, metadata );
|
CachingRegionFactory cachingRegionFactory,
|
||||||
|
String name,
|
||||||
|
CacheDataDescription metadata,
|
||||||
|
SessionFactoryOptions settings) {
|
||||||
|
super( cachingRegionFactory, name, metadata );
|
||||||
this.settings = settings;
|
this.settings = settings;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -23,8 +23,12 @@ class NaturalIdRegionImpl extends BaseTransactionalDataRegion implements Natural
|
||||||
|
|
||||||
private final SessionFactoryOptions settings;
|
private final SessionFactoryOptions settings;
|
||||||
|
|
||||||
NaturalIdRegionImpl(String name, CacheDataDescription metadata, SessionFactoryOptions settings) {
|
NaturalIdRegionImpl(
|
||||||
super( name, metadata );
|
CachingRegionFactory cachingRegionFactory,
|
||||||
|
String name,
|
||||||
|
CacheDataDescription metadata,
|
||||||
|
SessionFactoryOptions settings) {
|
||||||
|
super( cachingRegionFactory, name, metadata );
|
||||||
this.settings = settings;
|
this.settings = settings;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -48,11 +48,11 @@ class ReadWriteCollectionRegionAccessStrategy extends AbstractReadWriteAccessStr
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Object generateCacheKey(Object id, CollectionPersister persister, SessionFactoryImplementor factory, String tenantIdentifier) {
|
public Object generateCacheKey(Object id, CollectionPersister persister, SessionFactoryImplementor factory, String tenantIdentifier) {
|
||||||
return DefaultCacheKeysFactory.createCollectionKey( id, persister, factory, tenantIdentifier );
|
return region.getRegionFactory().getCacheKeysFactory().createCollectionKey( id, persister, factory, tenantIdentifier );
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Object getCacheKeyId(Object cacheKey) {
|
public Object getCacheKeyId(Object cacheKey) {
|
||||||
return DefaultCacheKeysFactory.getCollectionId( cacheKey );
|
return region.getRegionFactory().getCacheKeysFactory().getCollectionId( cacheKey );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -110,11 +110,11 @@ class ReadWriteEntityRegionAccessStrategy extends AbstractReadWriteAccessStrateg
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Object generateCacheKey(Object id, EntityPersister persister, SessionFactoryImplementor factory, String tenantIdentifier) {
|
public Object generateCacheKey(Object id, EntityPersister persister, SessionFactoryImplementor factory, String tenantIdentifier) {
|
||||||
return DefaultCacheKeysFactory.createEntityKey( id, persister, factory, tenantIdentifier );
|
return region.getRegionFactory().getCacheKeysFactory().createEntityKey( id, persister, factory, tenantIdentifier );
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Object getCacheKeyId(Object cacheKey) {
|
public Object getCacheKeyId(Object cacheKey) {
|
||||||
return DefaultCacheKeysFactory.getEntityId( cacheKey );
|
return region.getRegionFactory().getCacheKeysFactory().getEntityId( cacheKey );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -9,7 +9,6 @@ package org.hibernate.testing.cache;
|
||||||
import java.util.Comparator;
|
import java.util.Comparator;
|
||||||
|
|
||||||
import org.hibernate.cache.CacheException;
|
import org.hibernate.cache.CacheException;
|
||||||
import org.hibernate.cache.internal.DefaultCacheKeysFactory;
|
|
||||||
import org.hibernate.cache.spi.NaturalIdRegion;
|
import org.hibernate.cache.spi.NaturalIdRegion;
|
||||||
import org.hibernate.cache.spi.access.NaturalIdRegionAccessStrategy;
|
import org.hibernate.cache.spi.access.NaturalIdRegionAccessStrategy;
|
||||||
import org.hibernate.cache.spi.access.SoftLock;
|
import org.hibernate.cache.spi.access.SoftLock;
|
||||||
|
@ -107,11 +106,11 @@ class ReadWriteNaturalIdRegionAccessStrategy extends AbstractReadWriteAccessStra
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Object generateCacheKey(Object[] naturalIdValues, EntityPersister persister, SessionImplementor session) {
|
public Object generateCacheKey(Object[] naturalIdValues, EntityPersister persister, SessionImplementor session) {
|
||||||
return DefaultCacheKeysFactory.createNaturalIdKey( naturalIdValues, persister, session );
|
return region.getRegionFactory().getCacheKeysFactory().createNaturalIdKey( naturalIdValues, persister, session );
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Object[] getNaturalIdValues(Object cacheKey) {
|
public Object[] getNaturalIdValues(Object cacheKey) {
|
||||||
return DefaultCacheKeysFactory.getNaturalIdValues( cacheKey );
|
return region.getRegionFactory().getCacheKeysFactory().getNaturalIdValues( cacheKey );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue