All Downloads are FREE. Search and download functionalities are using the official Maven repository.

javax.cache.configuration.CompleteConfiguration Maven / Gradle / Ivy

There is a newer version: 1.1.1
Show newest version
/**
 *  Copyright (c) 2011-2013 Terracotta, Inc.
 *  Copyright (c) 2011-2013 Oracle and/or its affiliates.
 *
 *  All rights reserved. Use is subject to license terms.
 */

package javax.cache.configuration;

import javax.cache.expiry.ExpiryPolicy;
import javax.cache.integration.CacheLoader;
import javax.cache.integration.CacheWriter;
import java.io.Serializable;

/**
 * A read-only representation of the complete JCache {@link javax.cache.Cache}
 * configuration.
 * 

* The properties provided by instances of this interface are used by * {@link javax.cache.CacheManager}s to configure {@link javax.cache.Cache}s. *

* Implementations of this interface must override {@link Object#hashCode()} and * {@link Object#equals(Object)} as * {@link javax.cache.configuration.CompleteConfiguration}s are often compared at * runtime. * * @param the type of keys maintained the cache * @param the type of cached values * @author Greg Luck * @author Yannis Cosmadopoulos * @author Brian Oliver * @since 1.0 */ public interface CompleteConfiguration extends Configuration, Serializable { /** * Determines if a {@link javax.cache.Cache} should operate in read-through mode. *

* When in "read-through" mode, cache misses that occur due to cache entries * not existing as a result of performing a "get" will appropriately * cause the configured {@link javax.cache.integration.CacheLoader} to be * invoked. *

* The default value is false. * * @return true when a {@link javax.cache.Cache} is in * "read-through" mode. * @see #getCacheLoaderFactory() */ boolean isReadThrough(); /** * Determines if a {@link javax.cache.Cache} should operate in write-through * mode. *

* When in "write-through" mode, cache updates that occur as a result of * performing "put" operations called via one of * {@link javax.cache.Cache#put(Object, Object)}, * {@link javax.cache.Cache#getAndRemove(Object)}, * {@link javax.cache.Cache#removeAll()}, * {@link javax.cache.Cache#getAndPut(Object, Object)} * {@link javax.cache.Cache#getAndRemove(Object)}, * {@link javax.cache.Cache#getAndReplace(Object, * Object)}, {@link javax.cache.Cache#invoke(Object, * javax.cache.processor.EntryProcessor, * Object...)}, {@link javax.cache.Cache#invokeAll(java.util.Set, * javax.cache.processor.EntryProcessor, Object...)} will appropriately cause * the configured {@link javax.cache.integration.CacheWriter} to be invoked. *

* The default value is false. * * @return true when a {@link javax.cache.Cache} is in * "write-through" mode. * @see #getCacheWriterFactory() */ boolean isWriteThrough(); /** * Checks whether statistics collection is enabled in this cache. *

* The default value is false. * * @return true if statistics collection is enabled */ boolean isStatisticsEnabled(); /** * Checks whether management is enabled on this cache. *

* The default value is false. * * @return true if management is enabled */ boolean isManagementEnabled(); /** * Obtains the {@link javax.cache.configuration.CacheEntryListenerConfiguration}s * for {@link javax.cache.event.CacheEntryListener}s to be configured on a * {@link javax.cache.Cache}. * * @return an {@link Iterable} over the * {@link javax.cache.configuration.CacheEntryListenerConfiguration}s */ Iterable> getCacheEntryListenerConfigurations(); /** * Gets the {@link javax.cache.configuration.Factory} for the * {@link javax.cache.integration.CacheLoader}, if any. *

* A CacheLoader should be configured for "Read Through" caches to load values * when a cache miss occurs using either the * {@link javax.cache.Cache#get(Object)} and/or * {@link javax.cache.Cache#getAll(java.util.Set)} methods. *

* The default value is null. * * @return the {@link javax.cache.configuration.Factory} for the * {@link javax.cache.integration.CacheLoader} or null if none has been set. */ Factory> getCacheLoaderFactory(); /** * Gets the {@link javax.cache.configuration.Factory} for the * {@link javax.cache.integration.CacheWriter}, if any. *

* The default value is null. * * @return the {@link javax.cache.configuration.Factory} for the * {@link javax.cache.integration.CacheWriter} or null if none has been set. */ Factory> getCacheWriterFactory(); /** * Gets the {@link javax.cache.configuration.Factory} for the * {@link javax.cache.expiry.ExpiryPolicy} to be used for caches. *

* The default value is a {@link javax.cache.configuration.Factory} that will * produce a {@link javax.cache.expiry.EternalExpiryPolicy} instance. * * @return the {@link javax.cache.configuration.Factory} for * {@link javax.cache.expiry.ExpiryPolicy} (must not be null) */ Factory getExpiryPolicyFactory(); }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy