AdmMono/src/com/rjconsultores/ventaboletos/dao/hibernate/DispositivoEmbarcadaHiberna...

201 lines
6.4 KiB
Java

package com.rjconsultores.ventaboletos.dao.hibernate;
import java.util.List;
import org.hibernate.Criteria;
import org.hibernate.HibernateException;
import org.hibernate.Query;
import org.hibernate.SessionFactory;
import org.hibernate.criterion.Order;
import org.hibernate.criterion.Projections;
import org.hibernate.criterion.Property;
import org.hibernate.criterion.Restrictions;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Qualifier;
import org.springframework.stereotype.Repository;
import org.springframework.transaction.annotation.Transactional;
import com.rjconsultores.ventaboletos.dao.DispositivoEmbarcadaDAO;
import com.rjconsultores.ventaboletos.entidad.DispositivoEmbarcada;
import com.rjconsultores.ventaboletos.entidad.Empresa;
import com.rjconsultores.ventaboletos.entidad.FormaPagoDet;
import com.rjconsultores.ventaboletos.entidad.PtoVtaSeguro;
import com.rjconsultores.ventaboletos.entidad.PtovtaCatInd;
import com.rjconsultores.ventaboletos.entidad.PuntoVenta;
@SuppressWarnings("unchecked")
@Repository("dispositivoEmbarcadaDAO")
public class DispositivoEmbarcadaHibernateDAO extends GenericHibernateDAO<DispositivoEmbarcada, Long>
implements DispositivoEmbarcadaDAO {
@Autowired
public DispositivoEmbarcadaHibernateDAO(@Qualifier("sessionFactory") SessionFactory factory) {
setSessionFactory(factory);
}
@Override
public List<DispositivoEmbarcada> obtenerTodos() {
Criteria c = getSession().createCriteria(getPersistentClass());
c.add(Restrictions.eq(ACTIVO, Boolean.TRUE));
c.addOrder(Order.asc("descricao"));
return c.list();
}
@Override
public DispositivoEmbarcada buscarVersaoUltimaSinc(String versaoUltimaSinc) {
Criteria c = getSession().createCriteria(getPersistentClass());
c.add(Restrictions.eq(ACTIVO, Boolean.TRUE));
c.add(Restrictions.eq("versaoUltimaSinc", versaoUltimaSinc));
return (DispositivoEmbarcada) c.uniqueResult();
}
@Override
public List<String> buscarAllVersaoUltimaSinc() {
Criteria c = getSession().createCriteria(getPersistentClass());
c.setProjection(Projections.distinct(Property.forName("versaoUltimaSinc")));
c.add(Restrictions.isNotNull("versaoUltimaSinc"));
c.add(Restrictions.eq(ACTIVO, Boolean.TRUE));
c.addOrder(Order.asc("versaoUltimaSinc"));
return (List<String>) c.list();
}
@Override
public DispositivoEmbarcada buscarImeiDuplicado(String imei){
StringBuilder sb = new StringBuilder();
sb.append("select dp ");
sb.append("from DispositivoEmbarcada dp ");
sb.append("where dp.imei = :imei ");
Query query = getSession().createQuery(sb.toString());
query.setString("imei", imei);
List<DispositivoEmbarcada> list = query.list();
if (list.isEmpty()) {
return null;
}
return (DispositivoEmbarcada) list.get(0);
}
@Override
public DispositivoEmbarcada buscarImei(String imei) {
StringBuilder sb = new StringBuilder();
sb.append("select dp ");
sb.append("from DispositivoEmbarcada dp ");
sb.append(" inner join fetch dp.series as se ");
sb.append("where se.activo = 1 ");
sb.append(" and se.indBaixado = 0 ");
sb.append("and dp.imei = :imei ");
sb.append("and dp.activo = 1 ");
Query query = getSession().createQuery(sb.toString());
query.setString("imei", imei);
return (DispositivoEmbarcada) query.uniqueResult();
}
@Override
@Transactional
public DispositivoEmbarcada suscribir(DispositivoEmbarcada entity) {
try {
this.getHibernateTemplate().save(entity);
getHibernateTemplate().flush();
return entity;
} catch (final HibernateException ex) {
throw convertHibernateAccessException(ex);
}
}
@Override
@Transactional
public DispositivoEmbarcada actualizacion(DispositivoEmbarcada entity) {
entity = getHibernateTemplate().merge(entity);
getHibernateTemplate().flush();
return entity;
}
@Override
@Transactional
public DispositivoEmbarcada suscribirActualizar(DispositivoEmbarcada dispositivoEmbarcada) {
if (buscarDispositivoPorId(dispositivoEmbarcada) != null) {
actualizacion(dispositivoEmbarcada);
} else {
suscribir(dispositivoEmbarcada);
}
return dispositivoEmbarcada;
}
@Override
public DispositivoEmbarcada buscarDispositivoPorId(DispositivoEmbarcada dispositivoEmbarcada) {
Criteria c = getSession().createCriteria(getPersistentClass());
c.add(Restrictions.eq(ACTIVO, Boolean.TRUE));
c.add(Restrictions.eq("id", dispositivoEmbarcada.getDispositivoEmbarcadaId()));
return (DispositivoEmbarcada) c.uniqueResult();
}
@Override
public List<DispositivoEmbarcada> buscarPorEmpresaPuntoVenta(Empresa empresa, PuntoVenta puntoventa) {
StringBuilder sb = new StringBuilder();
sb.append("from DispositivoEmbarcada de ");
sb.append("where activo = 1 ");
sb.append("and de.empresaId = :empresaId ");
sb.append("and de.puntoVentaId = :puntoVentaId ");
Query qry = getSession().createQuery(sb.toString());
qry.setLong("empresaId", empresa.getEmpresaId());
qry.setLong("puntoVentaId", puntoventa.getPuntoventaId());
return qry.list();
}
@Override
public List<DispositivoEmbarcada> buscarTodos() {
StringBuilder sb = new StringBuilder();
sb.append("from DispositivoEmbarcada de ");
sb.append("where activo = 1 ");
Query qry = getSession().createQuery(sb.toString());
return qry.list();
}
@Override
public List<FormaPagoDet> getListaFormaPago(Integer puntoventaId) {
String queryStr = "from FormaPagoDet fp where fp.activo = true and fp.indEmbarcada = true and fp.puntoVenta.puntoventaId = :puntoventaId";
Query query = getSession().createQuery(queryStr);
query.setInteger("puntoventaId", puntoventaId);
return query.list();
}
@Override
public List<PtoVtaSeguro> getListaSeguroTaxaEmbarque(Integer puntoventaId) {
String queryStr = "from PtoVtaSeguro x where x.activo = true and x.puntoventaId.puntoventaId = :puntoventaId";
Query query = getSession().createQuery(queryStr);
query.setInteger("puntoventaId", puntoventaId);
return query.list();
}
@Override
public List<PtovtaCatInd> getListaTiposPassagensBloqueadas(Integer puntoventaId) {
String queryStr = "from PtovtaCatInd x where x.activo = true and x.indEmbarcada = true and x.puntoVenta.puntoventaId = :puntoventaId";
Query query = getSession().createQuery(queryStr);
query.setInteger("puntoventaId", puntoventaId);
return query.list();
}
}