PollFacade.java 2.11 KB
package fi.insomnia.bortal.facade;

import java.util.Date;
import java.util.List;

import javax.ejb.LocalBean;
import javax.ejb.Stateless;
import javax.persistence.EntityManager;
import javax.persistence.PersistenceContext;
import javax.persistence.criteria.CriteriaBuilder;
import javax.persistence.criteria.CriteriaQuery;
import javax.persistence.criteria.Root;

import fi.insomnia.bortal.model.LanEvent;
import fi.insomnia.bortal.model.Poll;
import fi.insomnia.bortal.model.Poll_;

@Stateless
@LocalBean
public class PollFacade extends GenericFacade<Integer, Poll> {

	@PersistenceContext
	private EntityManager em;

	public PollFacade() {
		super(Poll.class);
	}

	@Override
	protected EntityManager getEm() {
		return em;
	}

	// private boolean pollIsUsable(Poll poll) {
	// Date now = new Date();
	//
	// // Already valid
	// if (poll.getBegin().after(now)) {
	// logger.debug("Poll {} not opened yet", poll);
	// return false;
	// }
	//
	// // Still valid
	// if (poll.getEnd().before(now)) {
	// logger.debug("Poll {} already closed", poll);
	// return false;
	// }
	//
	// logger.debug("Poll has {} questions", poll.getQuestions());
	// // At least one question that is on a page
	// for (PollQuestion q : poll.getQuestions()) {
	// logger.debug("Check question  {} page {}", q, q.getPage());
	// if (q.getPage() > 0) {
	// return true;
	// }
	// }
	//
	// // No usable questions
	// return false;
	// }

	public List<Poll> findAllUsable(LanEvent currentEvent) {

		Date now = new Date();
		CriteriaBuilder cb = em.getCriteriaBuilder();
		CriteriaQuery<Poll> cq = cb.createQuery(Poll.class);
		Root<Poll> root = cq.from(Poll.class);

		cq.where(cb.equal(root.get(Poll_.event), currentEvent),
				cb.lessThan(root.get(Poll_.begin), now),
				cb.greaterThan(root.get(Poll_.end), now)
				);

		return em.createQuery(cq).getResultList();

	}

	public List<Poll> findAll(LanEvent currentEvent) {

		CriteriaBuilder cb = em.getCriteriaBuilder();
		CriteriaQuery<Poll> cq = cb.createQuery(Poll.class);
		Root<Poll> root = cq.from(Poll.class);

		cq.where(cb.equal(root.get(Poll_.event), currentEvent));
		return em.createQuery(cq).getResultList();

	}
}