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

com.erudika.para.cache.Cache Maven / Gradle / Ivy

There is a newer version: 1.50.3
Show newest version
/*
 * Copyright 2013-2017 Erudika. https://erudika.com
 *
 * 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.
 *
 * For issues and patches go to: https://github.com/erudika
 */
package com.erudika.para.cache;

import java.util.List;
import java.util.Map;

/**
 * This class manages object caching. An object is cached mainly for read performance and database offloading. The cache
 * can also be used to store transient data which is shared among all nodes of the system.
 *
 * @author Alex Bogdanovski [[email protected]]
 */
public interface Cache {

	/**
	 * Do we have this object in the cache?
	 * @param id the object's id
	 * @return true if in cache
	 */
	boolean contains(String id);

	/**
	 * Do we have this object in the cache?
	 * @param appid the name of the application
	 * @param id the object's id
	 * @return true if in cache
	 * @see #contains(java.lang.String)
	 */
	boolean contains(String appid, String id);

	/**
	 * Store an object in the cache.
	 * @param  the type of object to be cached
	 * @param id the object's id, not null or empty
	 * @param object the object itself, not null
	 */
	 void put(String id, T object);

	/**
	 * Store an object in the cache.
	 * @param appid the name of the application
	 * @param  the type of object to be cached
	 * @param id the object's id, not null or empty
	 * @param object the object itself, not null
	 * @see #put(java.lang.String, java.lang.Object)
	 */
	 void put(String appid, String id, T object);

	/**
	 * Store an object in the cache.
	 * @param appid the name of the application
	 * @param  the type of object to be cached
	 * @param id the object's id, not null or empty
	 * @param object the object itself, not null
	 * @param ttlSeconds the time to live for an object before it is evicted from the cache.
	 * @see #put(java.lang.String, java.lang.Object)
	 */
	 void put(String appid, String id, T object, Long ttlSeconds);

	/**
	 * Store all objects in cache, except those which are null.
	 * @param  any object, not null
	 * @param objects map of id - object
	 */
	 void putAll(Map objects);

	/**
	 * Store all objects in cache, except those which are null.
	 * @param appid the name of the application
	 * @param  any object, not null
	 * @param objects map of id - object
	 * @see #putAll(java.util.Map)
	 */
	 void putAll(String appid, Map objects);

	/**
	 * Read an object from cache.
	 * @param  the type of object to be cached
	 * @param id the object's id, not null or empty
	 * @return the object from cache or null if not found
	 */
	 T get(String id);

	/**
	 * Read an object from cache.
	 * @param appid the name of the application
	 * @param  the type of object to be cached
	 * @param id the object's id, not null or empty
	 * @return the object from cache or null if not found
	 * @see #get(java.lang.String)
	 */
	 T get(String appid, String id);

	/**
	 * Read a number of objects given a list of their ids.
	 * @param  the type of object to be cached
	 * @param ids the ids, not null or empty
	 * @return a map of the objects that are contained in cache (may be empty)
	 */
	 Map getAll(List ids);

	/**
	 * Read a number of objects given a list of their ids.
	 * @param appid the name of the application
	 * @param  the type of object to be cached
	 * @param ids the ids, not null or empty
	 * @return a map of the objects that are contained in cache (may be empty)
	 * @see #getAll(java.util.List)
	 */
	 Map getAll(String appid, List ids);

	/**
	 * Remove an object from cache.
	 * @param id the object's id, not null or empty
	 */
	void remove(String id);

	/**
	 * Remove an object from cache.
	 * @param appid the name of the application
	 * @param id the object's id, not null or empty
	 * @see #remove(java.lang.String)
	 */
	void remove(String appid, String id);

	/**
	 * Clears the cache.
	 */
	void removeAll();

	/**
	 * Clears the cache.
	 * @param appid the name of the application
	 * @see #removeAll()
	 */
	void removeAll(String appid);

	/**
	 * Remove a number of objects from cache given a list of their ids.
	 * @param ids the ids, not null or empty
	 */
	void removeAll(List ids);

	/**
	 * Remove a number of objects from cache given a list of their ids.
	 * @param ids the ids, not null or empty
	 * @param appid the name of the application
	 * @see #removeAll(java.util.List)
	 */
	void removeAll(String appid, List ids);
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy