
net.sf.ehcache.store.AbstractStore Maven / Gradle / Ivy
The newest version!
/**
* Copyright Terracotta, Inc.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package net.sf.ehcache.store;
import java.util.ArrayList;
import java.util.Collection;
import java.util.HashMap;
import java.util.HashSet;
import java.util.List;
import java.util.Map;
import java.util.Set;
import java.util.concurrent.ConcurrentHashMap;
import net.sf.ehcache.CacheException;
import net.sf.ehcache.Element;
import net.sf.ehcache.config.InvalidConfigurationException;
import net.sf.ehcache.search.Attribute;
import net.sf.ehcache.search.Results;
import net.sf.ehcache.search.attribute.AttributeExtractor;
import net.sf.ehcache.search.attribute.DynamicAttributesExtractor;
import net.sf.ehcache.search.impl.SearchManager;
import net.sf.ehcache.terracotta.TerracottaNotRunningException;
/**
* @author gkeim
*/
public abstract class AbstractStore implements Store {
/**
* search attribute extractors
*/
protected final Map attributeExtractors = new ConcurrentHashMap();
/**
* search manager
*/
protected final SearchManager searchManager;
/**
* listener list
*/
private transient List listenerList;
private final String cacheName;
/**
* Constructor for stores that do not support search
*/
protected AbstractStore() {
this(null, null);
}
/**
* Constructor for stores that do support search
*
* @param searchManager the search manager to use
*/
protected AbstractStore(SearchManager searchManager, String cacheName) {
this.searchManager = searchManager;
this.cacheName = cacheName;
}
/**
* onLoad initializer
*/
protected synchronized List getEventListenerList() {
if (listenerList == null) {
listenerList = new ArrayList();
}
return listenerList;
}
/**
* {@inheritDoc}
*
* @see net.sf.ehcache.store.Store#isCacheCoherent()
*/
public boolean isCacheCoherent() {
return false;
}
/**
* {@inheritDoc}
*
* @see net.sf.ehcache.store.Store#isClusterCoherent()
*/
public boolean isClusterCoherent() {
return false;
}
/**
* {@inheritDoc}
*
* @see net.sf.ehcache.store.Store#isNodeCoherent()
*/
public boolean isNodeCoherent() {
throw new UnsupportedOperationException();
}
/**
* {@inheritDoc}
*
* @see net.sf.ehcache.store.Store#setNodeCoherent(boolean)
*/
public void setNodeCoherent(boolean coherent) throws UnsupportedOperationException {
throw new UnsupportedOperationException();
}
/**
* {@inheritDoc}
*
* @throws InterruptedException
* @throws TerracottaNotRunningException
*
* @see net.sf.ehcache.store.Store#waitUntilClusterCoherent()
*/
public void waitUntilClusterCoherent() throws UnsupportedOperationException, TerracottaNotRunningException, InterruptedException {
throw new UnsupportedOperationException();
}
/**
* {@inheritDoc}
*
* @see net.sf.ehcache.store.Store#addStoreListener(net.sf.ehcache.store.StoreListener)
*/
public synchronized void addStoreListener(StoreListener listener) {
removeStoreListener(listener);
getEventListenerList().add(listener);
}
/**
* {@inheritDoc}
*
* @see net.sf.ehcache.store.Store#removeStoreListener(net.sf.ehcache.store.StoreListener)
*/
public synchronized void removeStoreListener(StoreListener listener) {
getEventListenerList().remove(listener);
}
/**
* {@inheritDoc}
*/
public void setAttributeExtractors(Map extractors) {
if (searchManager == null && !extractors.isEmpty()) {
throw new InvalidConfigurationException("Search attributes not supported by this store type: " + getClass().getName());
}
this.attributeExtractors.putAll(extractors);
}
/**
* {@inheritDoc}
*/
public Results executeQuery(StoreQuery query) {
if (searchManager == null) {
throw new UnsupportedOperationException("Query execution not supported by this store type: " + getClass().getName());
}
DynamicAttributesExtractor dynExtractor = query.getCache().getCacheConfiguration().getDynamicExtractor();
return searchManager.executeQuery(query, attributeExtractors, dynExtractor);
}
/**
* {@inheritDoc}
*/
public Attribute getSearchAttribute(String attributeName) throws CacheException {
Attribute attr = new Attribute(attributeName);
return getSearchAttributes().contains(attr) ? attr : null;
}
/**
* {@inheritDoc}
*/
@Override
public Set getSearchAttributes() {
if (searchManager == null) {
throw new InvalidConfigurationException("Search attributes not supported by this store type: " + getClass().getName());
}
return new HashSet(searchManager.getSearchAttributes(cacheName));
}
/**
* {@inheritDoc}
*/
public void putAll(Collection elements) throws CacheException {
for (Element element : elements) {
put(element);
}
}
/**
* {@inheritDoc}
*/
public void removeAll(Collection> keys) {
for (Object key : keys) {
remove(key);
}
}
/**
* {@inheritDoc}
*/
public Map
© 2015 - 2025 Weber Informatics LLC | Privacy Policy