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

play.cache.Cache Maven / Gradle / Ivy

There is a newer version: 2.6.3
Show newest version
package play.cache;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import play.Play;
import play.exceptions.CacheException;
import play.libs.Time;

import javax.annotation.Nonnull;
import javax.annotation.Nullable;
import java.io.NotSerializableException;
import java.io.Serializable;

/**
 * The Cache. Mainly an interface to memcached or EhCache.
 *
 * Note: When specifying expiration == "0s" (zero seconds) the actual expiration-time may vary between different cache implementations
 */
public abstract class Cache {
    private static final Logger logger = LoggerFactory.getLogger(Cache.class);

    /**
     * The underlying cache implementation
     */
    public static CacheImpl cacheImpl;

    /**
     * Set an element.
     * @param key Element key
     * @param value Element value
     * @param expiration Ex: 10s, 3mn, 8h
     */
    public static void set(String key, Object value, String expiration) {
        checkSerializable(value);
        cacheImpl.set(key, value, Time.parseDuration(expiration));
    }

    /**
     * Retrieve an object.
     * @param key The element key
     * @return The element value or null
     */
    @Nullable
    public static  T get(@Nonnull String key) {
        return (T) cacheImpl.get(key);
    }

    /**
     * Delete an element from the cache.
     * @param key The element key
     */
    public static void delete(String key) {
        cacheImpl.delete(key);
    }

    /**
     * Clear all data from cache.
     */
    public static void clear() {
        if (cacheImpl != null) {
            cacheImpl.clear();
        }
    }

    /**
     * Initialize the cache system.
     */
    public static void init() {
        if ("enabled".equals(Play.configuration.getProperty("memcached", "disabled"))) {
            try {
                cacheImpl = new MemcachedImpl(Play.configuration);
                logger.info("Connected to memcached");
            } catch (Exception e) {
                logger.error("Error while connecting to memcached", e);
                logger.warn("Fallback to local cache");
                cacheImpl = EhCacheImpl.newInstance();
            }
        } else {
            cacheImpl = EhCacheImpl.newInstance();
        }
    }

    /**
     * Stop the cache system.
     */
    public static void stop() {
        try {
            cacheImpl.stop();
        }
        catch (Exception e) {
            logger.error("Failed to stop the cache", e);
        }
    }

    /**
     * Utility that check that an object is serializable.
     */
    static void checkSerializable(Object value) {
        if(value != null && !(value instanceof Serializable)) {
            throw new CacheException("Cannot cache a non-serializable value of type " + value.getClass().getName(), new NotSerializableException(value.getClass().getName()));
        }
    }
}





© 2015 - 2024 Weber Informatics LLC | Privacy Policy