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

com.impetus.kundera.persistence.EntityManagerSession Maven / Gradle / Ivy

There is a newer version: 2.9
Show newest version
/*******************************************************************************
 * * Copyright 2012 Impetus Infotech.
 *  *
 *  * 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 com.impetus.kundera.persistence;

import java.util.Map;
import java.util.concurrent.ConcurrentHashMap;

import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;

import com.impetus.kundera.cache.Cache;

/**
 * The Class EntityManagerSession.
 */
public class EntityManagerSession
{

    /** The Constant log. */
    private static final Log LOG = LogFactory.getLog(EntityManagerSession.class);

    /** cache is used to store objects retrieved in this EntityManager session. */
    private Map sessionCache;

    /** The l2 cache. */
    private Cache l2Cache; // L2 Cache

    /**
     * Instantiates a new entity manager cache.
     * 
     * @param cache
     *            the cache
     */
    public EntityManagerSession(Cache cache)
    {
        this.sessionCache = new ConcurrentHashMap();
        setL2Cache(cache);
    }

    /**
     * Find in cache.
     * 
     * @param 
     *            the generic type
     * @param entityClass
     *            the entity class
     * @param id
     *            the id
     * @return the t
     */
    @SuppressWarnings("unchecked")
    protected  T lookup(Class entityClass, Object id)
    {
        String key = cacheKey(entityClass, id);
        LOG.debug("Reading from L1 >> " + key);
        T o = (T) sessionCache.get(key);

        // go to second-level cache
        if (o == null)
        {
            LOG.debug("Reading from L2 >> " + key);
            Cache c = (Cache) getL2Cache();
            if (c != null)
            {
                o = (T) c.get(key);
                if (o != null)
                {
                    LOG.debug("Found item in second level cache!");
                }
            }
        }
        return o;
    }

    /**
     * Store in L1 only.
     * 
     * @param id
     *            the id
     * @param entity
     *            the entity
     */
    protected void store(Object id, Object entity)
    {
        store(id, entity, Boolean.TRUE);
    }

    /**
     * Save to cache.
     * 
     * @param id
     *            the id
     * @param entity
     *            the entity
     * @param spillOverToL2
     *            the spill over to l2
     */
    protected void store(Object id, Object entity, boolean spillOverToL2)
    {
        String key = cacheKey(entity.getClass(), id);
        LOG.debug("Writing to L1 >> " + key);
        sessionCache.put(key, entity);

        if (spillOverToL2)
        {
            LOG.debug("Writing to L2 >>" + key);
            // save to second level cache
            Cache c = (Cache) getL2Cache();
            if (c != null)
            {
                c.put(key, entity);
            }
        }
    }

    /**
     * Removes the.
     * 
     * @param 
     *            the generic type
     * @param entityClass
     *            the entity class
     * @param id
     *            the id
     */
    protected  void remove(Class entityClass, Object id)
    {
        remove(entityClass, id, Boolean.TRUE);
    }

    /**
     * Removes the from cache.
     * 
     * @param 
     *            the generic type
     * @param entityClass
     *            the entity class
     * @param id
     *            the id
     * @param spillOverToL2
     *            the spill over to l2
     */
    protected  void remove(Class entityClass, Object id, boolean spillOverToL2)
    {
        String key = cacheKey(entityClass, id);
        LOG.debug("Removing from L1 >> " + key);
        Object o = sessionCache.remove(key);

        if (spillOverToL2)
        {
            LOG.debug("Removing from L2 >> " + key);
            Cache c = (Cache) getL2Cache();
            if (c != null)
            {
                c.evict(entityClass, key);
            }
        }
    }

    /**
     * Cache key.
     * 
     * @param clazz
     *            the clazz
     * @param id
     *            the id
     * 
     * @return the string
     */
    private String cacheKey(Class clazz, Object id)
    {
        return clazz.getName() + "_" + id;
    }

    /**
     * Clear.
     */
    public final void clear()
    {
        sessionCache = new ConcurrentHashMap();

        // Clear L2 Cahce
        if (getL2Cache() != null)
        {
            getL2Cache().evictAll();
        }
    }

    /**
     * Gets the l2 cache.
     * 
     * @return the l2Cache
     */
    public Cache getL2Cache()
    {
        return l2Cache;
    }

    /**
     * Sets the l2 cache.
     * 
     * @param l2Cache
     *            the l2Cache to set
     */
    public void setL2Cache(Cache l2Cache)
    {
        this.l2Cache = l2Cache;
    }

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy