package dao;
// Generated Oct 23, 2017 4:32:37 PM by Hibernate Tools 3.5.0.Final

import java.util.List;
import javax.naming.InitialContext;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.hibernate.LockMode;
import org.hibernate.SessionFactory;

import model.Realisateurfilmsdrama;

import static org.hibernate.criterion.Example.create;

/**
 * Home object for domain model class Realisateurfilmsdrama.
 * @see dao.Realisateurfilmsdrama
 * @author Hibernate Tools
 */
public class RealisateurfilmsdramaHome {

	private static final Log log = LogFactory.getLog(RealisateurfilmsdramaHome.class);

	private final SessionFactory sessionFactory = getSessionFactory();

	protected SessionFactory getSessionFactory() {
		try {
			return (SessionFactory) new InitialContext().lookup("SessionFactory");
		} catch (Exception e) {
			log.error("Could not locate SessionFactory in JNDI", e);
			throw new IllegalStateException("Could not locate SessionFactory in JNDI");
		}
	}

	public void persist(Realisateurfilmsdrama transientInstance) {
		log.debug("persisting Realisateurfilmsdrama instance");
		try {
			sessionFactory.getCurrentSession().persist(transientInstance);
			log.debug("persist successful");
		} catch (RuntimeException re) {
			log.error("persist failed", re);
			throw re;
		}
	}

	public void attachDirty(Realisateurfilmsdrama instance) {
		log.debug("attaching dirty Realisateurfilmsdrama instance");
		try {
			sessionFactory.getCurrentSession().saveOrUpdate(instance);
			log.debug("attach successful");
		} catch (RuntimeException re) {
			log.error("attach failed", re);
			throw re;
		}
	}

	public void attachClean(Realisateurfilmsdrama instance) {
		log.debug("attaching clean Realisateurfilmsdrama instance");
		try {
			sessionFactory.getCurrentSession().lock(instance, LockMode.NONE);
			log.debug("attach successful");
		} catch (RuntimeException re) {
			log.error("attach failed", re);
			throw re;
		}
	}

	public void delete(Realisateurfilmsdrama persistentInstance) {
		log.debug("deleting Realisateurfilmsdrama instance");
		try {
			sessionFactory.getCurrentSession().delete(persistentInstance);
			log.debug("delete successful");
		} catch (RuntimeException re) {
			log.error("delete failed", re);
			throw re;
		}
	}

	public Realisateurfilmsdrama merge(Realisateurfilmsdrama detachedInstance) {
		log.debug("merging Realisateurfilmsdrama instance");
		try {
			Realisateurfilmsdrama result = (Realisateurfilmsdrama) sessionFactory.getCurrentSession()
					.merge(detachedInstance);
			log.debug("merge successful");
			return result;
		} catch (RuntimeException re) {
			log.error("merge failed", re);
			throw re;
		}
	}

	public Realisateurfilmsdrama findById(dao.RealisateurfilmsdramaId id) {
		log.debug("getting Realisateurfilmsdrama instance with id: " + id);
		try {
			Realisateurfilmsdrama instance = (Realisateurfilmsdrama) sessionFactory.getCurrentSession()
					.get("dao.Realisateurfilmsdrama", id);
			if (instance == null) {
				log.debug("get successful, no instance found");
			} else {
				log.debug("get successful, instance found");
			}
			return instance;
		} catch (RuntimeException re) {
			log.error("get failed", re);
			throw re;
		}
	}

	public List<Realisateurfilmsdrama> findByExample(Realisateurfilmsdrama instance) {
		log.debug("finding Realisateurfilmsdrama instance by example");
		try {
			List<Realisateurfilmsdrama> results = (List<Realisateurfilmsdrama>) sessionFactory.getCurrentSession()
					.createCriteria("dao.Realisateurfilmsdrama").add(create(instance)).list();
			log.debug("find by example successful, result size: " + results.size());
			return results;
		} catch (RuntimeException re) {
			log.error("find by example failed", re);
			throw re;
		}
	}
}
