mirror of
https://github.com/DSpace/DSpace.git
synced 2025-10-19 07:53:08 +00:00
[DS-247] [DS-243] [DSB-37] Extraction of complete DSpace 2.0 Kernel, RequestService, SessionService, EventService and CachingServices.
git-svn-id: http://scm.dspace.org/svn/repo/modules/dspace-services/trunk@4100 9c30dcfa-912a-0410-8fc2-9e0234be79fd
This commit is contained in:
144
api/src/main/java/org/dspace/services/CachingService.java
Normal file
144
api/src/main/java/org/dspace/services/CachingService.java
Normal file
@@ -0,0 +1,144 @@
|
||||
/*
|
||||
* $URL: https://scm.dspace.org/svn/repo/dspace2/core/trunk/api/src/main/java/org/dspace/services/CachingService.java $
|
||||
*
|
||||
* $Revision: 3253 $
|
||||
*
|
||||
* $Date: 2008-10-30 05:02:18 -0700 (Thu, 30 Oct 2008) $
|
||||
*
|
||||
* Copyright (c) 2008, The DSpace Foundation. All rights reserved.
|
||||
*
|
||||
* Redistribution and use in source and binary forms, with or without
|
||||
* modification, are permitted provided that the following conditions are
|
||||
* met:
|
||||
*
|
||||
* - Redistributions of source code must retain the above copyright
|
||||
* notice, this list of conditions and the following disclaimer.
|
||||
*
|
||||
* - Redistributions in binary form must reproduce the above copyright
|
||||
* notice, this list of conditions and the following disclaimer in the
|
||||
* documentation and/or other materials provided with the distribution.
|
||||
*
|
||||
* - Neither the name of the DSpace Foundation nor the names of its
|
||||
* contributors may be used to endorse or promote products derived from
|
||||
* this software without specific prior written permission.
|
||||
*
|
||||
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
||||
* ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
||||
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
||||
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
||||
* HOLDERS OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
|
||||
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
|
||||
* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
|
||||
* OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
|
||||
* ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR
|
||||
* TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE
|
||||
* USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH
|
||||
* DAMAGE.
|
||||
*/
|
||||
|
||||
package org.dspace.services;
|
||||
|
||||
import java.util.List;
|
||||
|
||||
import org.dspace.services.model.Cache;
|
||||
import org.dspace.services.model.CacheConfig;
|
||||
|
||||
/**
|
||||
* A service to manage creation and retrieval of caches
|
||||
*
|
||||
* @author Aaron Zeckoski (azeckoski @ gmail.com)
|
||||
*/
|
||||
public interface CachingService {
|
||||
|
||||
/**
|
||||
* This is the cache key used to stored requests in a request cache,
|
||||
* typically handled by a servlet filter but can be handled by anything,
|
||||
* this is here to ensure we use the right name
|
||||
*/
|
||||
public static final String REQUEST_CACHE = "dsRequestCache";
|
||||
/**
|
||||
* This is the key in the request cache which holds the current http request (if there is one)
|
||||
*/
|
||||
public static final String HTTP_REQUEST_KEY = "httpRequest";
|
||||
/**
|
||||
* This is the key in the request cache which holds the current http response (if there is one)
|
||||
*/
|
||||
public static final String HTTP_RESPONSE_KEY = "httpResponse";
|
||||
/**
|
||||
* This is the key in the request cache which holds the current request
|
||||
*/
|
||||
public static final String REQUEST_KEY = "request";
|
||||
/**
|
||||
* This is the key in the request cache which holds the current response
|
||||
*/
|
||||
public static final String RESPONSE_KEY = "response";
|
||||
/**
|
||||
* This is the key in the request cache which holds the current locale
|
||||
*/
|
||||
public static final String LOCALE_KEY = "locale";
|
||||
/**
|
||||
* This is the key in the request cache which holds the current session ID
|
||||
*/
|
||||
public static final String SESSION_ID_KEY = "session";
|
||||
/**
|
||||
* This is the key in the request cache which holds the current request ID
|
||||
*/
|
||||
public static final String REQUEST_ID_KEY = "requestId";
|
||||
|
||||
/**
|
||||
* Gets all the caches that the service knows about,
|
||||
* this will include caches of all scopes but only includes request caches for the current thread
|
||||
*
|
||||
* @return a list of all the caches which the caching service knows about
|
||||
*/
|
||||
public List<Cache> getCaches();
|
||||
|
||||
/**
|
||||
* Construct a Cache with the given name (often this is the fully qualified classpath of the api
|
||||
* for the service that is being cached or the class if there is no api) OR retrieve the one
|
||||
* that already exists with this name,
|
||||
* this will operate on system defaults (probably a distributed cache without replication) OR
|
||||
* it will use the defaults which are configured for this cacheName (part of the underlying implementation)
|
||||
* if the cacheConfig is null <br/>
|
||||
* This can only retrieve request caches for the current request <br/>
|
||||
* If the cache already exists then the cacheConfig is ignored <br/>
|
||||
*
|
||||
* @param cacheName the unique name for this cache (e.g. org.dspace.user.UserCache)
|
||||
* @param cacheConfig defines the configuration for this cache
|
||||
* @return a cache which can be used to store objects
|
||||
*/
|
||||
public Cache getCache(String cacheName, CacheConfig cacheConfig);
|
||||
|
||||
/**
|
||||
* Flushes and destroys the cache with this name,
|
||||
* generally there is no reason to call this
|
||||
*
|
||||
* @param cacheName the unique name for this cache (e.g. org.dspace.user.UserCache)
|
||||
*/
|
||||
public void destroyCache(String cacheName);
|
||||
|
||||
/**
|
||||
* Get a status report of cache usage which is suitable for log or screen output
|
||||
*
|
||||
* @param cacheName (optional) the unique name for this cache (e.g. org.dspace.user.UserCache)
|
||||
* OR null for status of all caches
|
||||
* @return a string representing the current status of the specified cache or all caches
|
||||
*/
|
||||
public String getStatus(String cacheName);
|
||||
|
||||
/**
|
||||
* Clears all caches,
|
||||
* generally there is no reason to call this
|
||||
*
|
||||
* @throws SecurityException if the current user does not have super user permissions
|
||||
*/
|
||||
public void resetCaches();
|
||||
|
||||
/**
|
||||
* Unbinds all request caches, destroys the caches completely,
|
||||
* you should not call this unless you know what you are doing,
|
||||
* it is handled automatically by the system
|
||||
*/
|
||||
public void unbindRequestCaches();
|
||||
|
||||
}
|
Reference in New Issue
Block a user