view flys-backend/src/main/java/de/intevation/flys/backend/SedDBSessionHolder.java @ 5216:c0bdbe24c115

INFO instead of WARNING for duplicated annotations
author Tom Gottfried <tom@intevation.de>
date Mon, 11 Mar 2013 13:22:50 +0100
parents 76c75c8b9ee0
children
line wrap: on
line source
package de.intevation.flys.backend;

import org.apache.log4j.Logger;

import org.hibernate.Session;
import org.hibernate.SessionFactory;

public class SedDBSessionHolder
{
    private static Logger log =
        Logger.getLogger(SedDBSessionHolder.class);

    public static final ThreadLocal<Session> HOLDER =
        new ThreadLocal<Session>() {
            @Override
            protected Session initialValue() {
                return create();
            }
        };

    private SedDBSessionHolder() {
    }

    public synchronized static Session create() {
        log.debug("create");
        SessionFactory sessionFactory =
            SessionFactoryProvider.getSedDBSessionFactory();
        return sessionFactory.openSession();
    }

    public static Session acquire() {
        log.debug("acquire");
        Session session = create();
        HOLDER.set(session);
        return session;
    }

    public static void release() {
        log.debug("release");
        HOLDER.remove();
    }
}
// vim:set ts=4 sw=4 si et sta sts=4 fenc=utf8 :

http://dive4elements.wald.intevation.org