com.ar.dev.tierra.api.dao.impl.FacturaDAOImpl.java Source code

Java tutorial

Introduction

Here is the source code for com.ar.dev.tierra.api.dao.impl.FacturaDAOImpl.java

Source

/*
 * To change this license header, choose License Headers in Project Properties.
 * To change this template file, choose Tools | Templates
 * and open the template in the editor.
 */
package com.ar.dev.tierra.api.dao.impl;

import com.ar.dev.tierra.api.dao.FacturaDAO;
import com.ar.dev.tierra.api.model.Factura;
import java.io.Serializable;
import java.util.Calendar;
import java.util.Date;
import java.util.List;
import org.hibernate.Criteria;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.criterion.MatchMode;
import org.hibernate.criterion.Order;
import org.hibernate.criterion.Restrictions;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Repository;
import org.springframework.transaction.annotation.Transactional;

/**
 *
 * @author PauloGaldo
 */
@Repository
@Transactional
public class FacturaDAOImpl implements FacturaDAO {

    @Autowired
    private SessionFactory sessionFactory;

    private Session getSession() {
        return sessionFactory.getCurrentSession();
    }

    @SuppressWarnings("unchecked")
    @Override
    public List<Factura> getAll() {
        Criteria criteria = getSession().createCriteria(Factura.class);
        criteria.add(Restrictions.not(Restrictions.in("estado", new String[] { "RESERVADO" })));
        criteria.setResultTransformer(Criteria.DISTINCT_ROOT_ENTITY);
        List<Factura> list = criteria.list();
        return list;
    }

    @Override
    public List<Factura> getDiary() {
        Criteria criteria = getSession().createCriteria(Factura.class);
        Calendar calendar = Calendar.getInstance();
        calendar.set(Calendar.HOUR_OF_DAY, 0);
        calendar.set(Calendar.MINUTE, 0);
        calendar.set(Calendar.SECOND, 0);
        Date fromDate = calendar.getTime();
        calendar.set(Calendar.HOUR_OF_DAY, 23);
        calendar.set(Calendar.MINUTE, 59);
        calendar.set(Calendar.SECOND, 59);
        Date toDate = calendar.getTime();
        criteria.add(Restrictions.between("fechaCreacion", fromDate, toDate));
        criteria.addOrder(Order.asc("idFactura"));
        criteria.add(Restrictions.not(Restrictions.in("estado", new String[] { "RESERVADO" })));
        criteria.setResultTransformer(Criteria.DISTINCT_ROOT_ENTITY);
        criteria.addOrder(Order.desc("idFactura"));
        List<Factura> list = criteria.list();
        return list;
    }

    @Override
    public List<Factura> getMonth() {
        Criteria criteria = getSession().createCriteria(Factura.class);
        Calendar calendar = Calendar.getInstance();
        Date toDate = calendar.getTime();
        calendar.add(Calendar.MONTH, -1);
        Date fromDate = calendar.getTime();
        criteria.add(Restrictions.between("fechaCreacion", fromDate, toDate));
        criteria.add(Restrictions.not(Restrictions.in("estado", new String[] { "RESERVADO" })));
        criteria.setResultTransformer(Criteria.DISTINCT_ROOT_ENTITY);
        criteria.addOrder(Order.desc("idFactura"));
        List<Factura> list = criteria.list();
        return list;
    }

    @Override
    public List<Factura> getDiaryReserva() {
        Criteria criteria = getSession().createCriteria(Factura.class);
        Calendar calendar = Calendar.getInstance();
        calendar.set(Calendar.HOUR_OF_DAY, 0);
        calendar.set(Calendar.MINUTE, 0);
        calendar.set(Calendar.SECOND, 0);
        Date fromDate = calendar.getTime();
        calendar.set(Calendar.HOUR_OF_DAY, 23);
        calendar.set(Calendar.MINUTE, 59);
        calendar.set(Calendar.SECOND, 59);
        Date toDate = calendar.getTime();
        criteria.add(Restrictions.between("fechaCreacion", fromDate, toDate));
        criteria.addOrder(Order.desc("idFactura"));
        criteria.add(Restrictions
                .not(Restrictions.in("estado", new String[] { "INICIADO", "CONFIRMADO", "CANCELADO" })));
        criteria.setResultTransformer(Criteria.DISTINCT_ROOT_ENTITY);
        List<Factura> list = criteria.list();
        return list;
    }

    @Override
    public List<Factura> getMonthReserva() {
        Criteria criteria = getSession().createCriteria(Factura.class);
        Calendar calendar = Calendar.getInstance();
        Date toDate = calendar.getTime();
        calendar.add(Calendar.MONTH, -1);
        Date fromDate = calendar.getTime();
        criteria.add(Restrictions.between("fechaCreacion", fromDate, toDate));
        criteria.add(Restrictions
                .not(Restrictions.in("estado", new String[] { "INICIADO", "CONFIRMADO", "CANCELADO" })));
        criteria.setResultTransformer(Criteria.DISTINCT_ROOT_ENTITY);
        criteria.addOrder(Order.desc("idFactura"));
        List<Factura> list = criteria.list();
        return list;
    }

    @Override
    public void update(Factura factura) {
        getSession().update(factura);
    }

    @Override
    public int add(Factura factura) {
        Serializable idFactura = getSession().save(factura);
        return (int) idFactura;
    }

    @Override
    public void delete(Factura factura) {
        getSession().delete(factura);
    }

    @Override
    public Factura searchById(int idFactura) {
        Criteria criteria = getSession().createCriteria(Factura.class);
        criteria.add(Restrictions.eq("idFactura", idFactura));
        Factura foundFactura = (Factura) criteria.uniqueResult();
        return foundFactura;
    }

    @Override
    public List<Factura> findByRegalo(String serial) {
        Criteria criteria = getSession().createCriteria(Factura.class);
        Calendar calendar = Calendar.getInstance();
        Date toDate = calendar.getTime();
        calendar.add(Calendar.MONTH, -1);
        Date fromDate = calendar.getTime();
        criteria.add(Restrictions.between("fechaCreacion", fromDate, toDate));
        criteria.add(Restrictions.ilike("regalo", serial, MatchMode.ANYWHERE));
        return criteria.list();
    }

}