org.hoteia.qalingo.core.dao.EmailDao.java Source code

Java tutorial

Introduction

Here is the source code for org.hoteia.qalingo.core.dao.EmailDao.java

Source

/**
 * 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.io.ByteArrayOutputStream;
import java.io.IOException;
import java.io.ObjectOutputStream;
import java.sql.Blob;
import java.sql.Timestamp;
import java.util.Date;
import java.util.Iterator;
import java.util.List;

import org.apache.commons.lang.StringUtils;
import org.hibernate.Criteria;
import org.hibernate.Hibernate;
import org.hibernate.Query;
import org.hibernate.Session;
import org.hibernate.criterion.Order;
import org.hibernate.criterion.Projections;
import org.hibernate.criterion.Restrictions;
import org.hoteia.qalingo.core.domain.Email;
import org.hoteia.qalingo.core.util.impl.MimeMessagePreparatorImpl;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.stereotype.Repository;

@Repository("emailDao")
public class EmailDao extends AbstractGenericDao {

    private final Logger logger = LoggerFactory.getLogger(getClass());

    public Email getEmailById(final Long emailId, Object... params) {
        Criteria criteria = createDefaultCriteria(Email.class);
        criteria.add(Restrictions.eq("id", emailId));
        Email email = (Email) criteria.uniqueResult();
        return email;
    }

    public List<Email> findEmailByStatus(final String status, Object... params) {
        Criteria criteria = createDefaultCriteria(Email.class);
        criteria.add(Restrictions.eq("status", status));

        criteria.addOrder(Order.asc("id"));

        @SuppressWarnings("unchecked")
        List<Email> emails = criteria.list();
        return emails;
    }

    public List<Long> findIdsForEmailSync(Object... params) {
        Criteria criteria = createDefaultCriteria(Email.class);
        criteria.add(Restrictions.or(Restrictions.eq("status", Email.EMAIl_STATUS_PENDING),
                Restrictions.eq("status", Email.EMAIl_STATUS_ERROR)));
        criteria.add(Restrictions.le("processedCount", 5));

        criteria.setProjection(Projections.property("id"));//Property.forName()

        criteria.addOrder(Order.asc("id"));

        @SuppressWarnings("unchecked")
        List<Long> emailIds = criteria.list();
        //        List<Long> emailIds = new ArrayList<Long>(emails.size());
        //        for (Iterator<Email> iterator = emails.iterator(); iterator.hasNext();) {
        //            Email email = (Email) iterator.next();
        //            emailIds.add(email.getId());
        //        }
        return emailIds;
    }

    public List<Long> findIdsForEmailSync(final String type, Object... params) {
        Criteria criteria = createDefaultCriteria(Email.class);
        criteria.add(Restrictions.eq("type", type));
        criteria.add(Restrictions.or(Restrictions.eq("status", Email.EMAIl_STATUS_PENDING),
                Restrictions.eq("status", Email.EMAIl_STATUS_ERROR)));
        criteria.add(Restrictions.le("processedCount", 5));

        criteria.setProjection(Projections.property("id"));//Property.forName()

        criteria.addOrder(Order.asc("id"));

        @SuppressWarnings("unchecked")
        List<Long> emailIds = criteria.list();
        //        List<Long> emailIds = new ArrayList<Long>(emails.size());
        //        for (Iterator<Email> iterator = emails.iterator(); iterator.hasNext();) {
        //            Email email = (Email) iterator.next();
        //            emailIds.add(email.getId());
        //        }
        return emailIds;
    }

    public Email saveOrUpdateEmail(final Email email) {
        if (email.getDateCreate() == null) {
            email.setDateCreate(new Timestamp(new Date().getTime()));
        }
        if (StringUtils.isEmpty(email.getStatus())) {
            email.setStatus(Email.EMAIl_STATUS_PENDING);
        }
        email.setDateUpdate(new Timestamp(new Date().getTime()));

        if (email.getId() != null) {
            //            if(em.contains(email)){
            //                em.refresh(email);
            //            }
            Email mergedEmail = em.merge(email);
            //            em.flush();
            return mergedEmail;
        } else {
            em.persist(email);
            return email;
        }
    }

    /**
     * @throws IOException
     * @see org.hoteia.qalingo.core.dao.EmailDao#saveEmail(Email email,
     *      MimeMessagePreparatorImpl mimeMessagePreparator)
     */
    public Email saveEmail(final Email email, final MimeMessagePreparatorImpl mimeMessagePreparator)
            throws IOException {
        Session session = (Session) em.getDelegate();

        ByteArrayOutputStream bos = new ByteArrayOutputStream();
        ObjectOutputStream oos = new ObjectOutputStream(bos);

        oos.writeObject(mimeMessagePreparator);
        oos.flush();
        oos.close();
        bos.close();

        byte[] data = bos.toByteArray();

        Blob blob = Hibernate.getLobCreator(session).createBlob(data);

        email.setEmailContent(blob);

        return saveOrUpdateEmail(email);
    }

    /**
     * @throws IOException
     * @see org.hoteia.qalingo.core.dao.EmailDao#saveEmail(Email email,
     *      Exception e)
     */
    public Email saveEmail(final Email email, final Exception exception) throws IOException {
        handleEmailException(email, exception);
        return saveOrUpdateEmail(email);
    }

    /**
     * @throws IOException
     * @see org.hoteia.qalingo.core.dao.EmailDao#handleEmailException(Email
     *      email, Exception e)
     */
    public void handleEmailException(final Email email, final Exception exception) throws IOException {
        Blob blob = convertObjectToBlobHibernate(exception);
        email.setExceptionContent(blob);
    }

    public void deleteEmail(final Email email) {
        em.remove(em.contains(email) ? email : em.merge(email));
    }

    public int deleteSendedEmail(final Timestamp before) {
        Session session = (Session) em.getDelegate();
        String sql = "FROM Email WHERE dateCreate <= :before AND status = '" + Email.EMAIl_STATUS_SENDED + "'";
        Query query = session.createQuery(sql);
        query.setTimestamp("before", before);
        List<Email> emails = (List<Email>) query.list();
        if (emails != null) {
            for (Iterator<Email> iterator = emails.iterator(); iterator.hasNext();) {
                Email email = (Email) iterator.next();
                deleteEmail(email);
            }
            return emails.size();
        }
        return 0;
    }

}