/** * Most of the code in the Qalingo project is copyrighted Hoteia and licensed * under the Apache License Version 2.0 (release version 0.8.0) * http://www.apache.org/licenses/LICENSE-2.0 * * Copyright (c) Hoteia, 2012-2014 * http://www.hoteia.com - http://twitter.com/hoteia - contact@hoteia.com * */ package org.hoteia.qalingo.core.dao; import java.sql.Timestamp; import java.util.Date; import java.util.Iterator; import java.util.List; import javax.persistence.criteria.CriteriaBuilder; import javax.persistence.criteria.CriteriaQuery; import javax.persistence.criteria.Root; import org.hibernate.Criteria; import org.hibernate.Query; import org.hibernate.Session; import org.hibernate.criterion.Restrictions; import org.hoteia.qalingo.core.domain.EngineBoSession; import org.hoteia.qalingo.core.domain.EngineEcoSession; import org.hoteia.qalingo.core.util.CoreUtil; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.stereotype.Repository; @Repository("engineSessionDao") public class EngineSessionDao extends AbstractGenericDao { private final Logger logger = LoggerFactory.getLogger(getClass()); // ECO SESSION // public static volatile SetAttribute<EngineEcoSession, Cart> carts; // public static volatile SetAttribute<Cart, CartItem> cartItems; // public static volatile SetAttribute<Cart, CurrencyReferential> cartCurrency; public EngineEcoSession getEngineEcoSessionById(final Long engineSessionId, Object... params) { CriteriaBuilder builder = em.getCriteriaBuilder(); CriteriaQuery<EngineEcoSession> criteriaQuery = builder.createQuery(EngineEcoSession.class); Root<EngineEcoSession> root = criteriaQuery.from( EngineEcoSession.class ); criteriaQuery.where(builder.equal(root.get("id"), engineSessionId)); EngineEcoSession engineSession = (EngineEcoSession) em.createQuery(criteriaQuery).getSingleResult(); return engineSession; } public EngineEcoSession getEngineEcoSessionByEngineSessionGuid(final String engineSessionGuid, Object... params) { CriteriaBuilder builder = em.getCriteriaBuilder(); CriteriaQuery<EngineEcoSession> criteriaQuery = builder.createQuery(EngineEcoSession.class); Root<EngineEcoSession> root = criteriaQuery.from( EngineEcoSession.class ); criteriaQuery.where(builder.equal(root.get("engineSessionGuid"), engineSessionGuid)); EngineEcoSession engineSession = (EngineEcoSession) em.createQuery(criteriaQuery).getSingleResult(); return engineSession; } public EngineEcoSession saveOrUpdateEngineEcoSession(EngineEcoSession engineSession) { if (engineSession.getEngineSessionGuid() == null) { engineSession.setEngineSessionGuid(CoreUtil.generateEntityCode()); } if (engineSession.getDateCreate() == null) { engineSession.setDateCreate(new Date()); } engineSession.setDateUpdate(new Date()); if (engineSession.getId() != null) { if(em.contains(engineSession)){ em.refresh(engineSession); } EngineEcoSession mergedEngineEcoSession = em.merge(engineSession); em.flush(); return mergedEngineEcoSession; } else { em.persist(engineSession); return engineSession; } } public void deleteEngineEcoSession(EngineEcoSession engineSession) { em.remove(em.contains(engineSession) ? engineSession : em.merge(engineSession)); } public int deleteEngineEcoSession(final Timestamp before) { Session session = (Session) em.getDelegate(); String sql = "FROM EngineEcoSession WHERE dateCreate <= :before"; Query query = session.createQuery(sql); query.setTimestamp("before", before); List<EngineEcoSession> sessions = (List<EngineEcoSession>) query.list(); if (sessions != null) { for (Iterator<EngineEcoSession> iterator = sessions.iterator(); iterator.hasNext();) { EngineEcoSession engineSession = (EngineEcoSession) iterator.next(); deleteEngineEcoSession(engineSession); } return sessions.size(); } return 0; } // BO SESSION public EngineBoSession getEngineBoSessionById(final Long engineSessionId, Object... params) { Criteria criteria = createDefaultCriteria(EngineBoSession.class); criteria.add(Restrictions.eq("id", engineSessionId)); EngineBoSession engineSession = (EngineBoSession) criteria.uniqueResult(); return engineSession; } public EngineBoSession getEngineBoSessionByEngineSessionGuid(final String engineSessionGuid, Object... params) { Criteria criteria = createDefaultCriteria(EngineBoSession.class); criteria.add(Restrictions.eq("engineSessionGuid", engineSessionGuid)); EngineBoSession engineSession = (EngineBoSession) criteria.uniqueResult(); return engineSession; } public EngineBoSession saveOrUpdateEngineBoSession(EngineBoSession engineSession) { if (engineSession.getEngineSessionGuid() == null) { engineSession.setEngineSessionGuid(CoreUtil.generateEntityCode()); } if (engineSession.getDateCreate() == null) { engineSession.setDateCreate(new Date()); } engineSession.setDateUpdate(new Date()); return em.merge(engineSession); } public void deleteEngineBoSession(EngineBoSession engineSession) { em.remove(em.contains(engineSession) ? engineSession : em.merge(engineSession)); } public int deleteEngineBoSession(final Timestamp before) { Session session = (Session) em.getDelegate(); String sql = "FROM EngineBoSession WHERE dateCreate <= :before"; Query query = session.createQuery(sql); query.setTimestamp("before", before); List<EngineBoSession> sessions = (List<EngineBoSession>) query.list(); if (sessions != null) { for (Iterator<EngineBoSession> iterator = sessions.iterator(); iterator.hasNext();) { EngineBoSession engineSession = (EngineBoSession) iterator.next(); deleteEngineBoSession(engineSession); } return sessions.size(); } return 0; } }