BillFacade.java 3.33 KB
/*
 * Copyright Codecrew Ry
 * 
 * All rights reserved.
 * 
 * This license applies to any software containing a notice placed by the 
 * copyright holder. Such software is herein referred to as the Software. 
 * This license covers modification, distribution and use of the Software. 
 * 
 * Any distribution and use in source and binary forms, with or without 
 * modification is not permitted without explicit written permission from the 
 * copyright owner. 
 * 
 * A non-exclusive royalty-free right is granted to the copyright owner of the 
 * Software to use, modify and distribute all modifications to the Software in 
 * future versions of the Software. 
 * 
 */
package fi.codecrew.moya.facade;

import java.util.ArrayList;
import java.util.List;

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

import fi.codecrew.moya.beans.EventBeanLocal;
import fi.codecrew.moya.entitysearch.BillSearchQuery;
import fi.codecrew.moya.facade.callbacks.bill.BillEventPredicate;
import fi.codecrew.moya.facade.callbacks.bill.BillFilterPredicate;
import fi.codecrew.moya.facade.callbacks.bill.BillOrderPredicate;
import fi.codecrew.moya.facade.callbacks.bill.BillUserPredicate;
import fi.codecrew.moya.model.Bill;
import fi.codecrew.moya.model.Bill_;
import fi.codecrew.moya.model.EventUser;
import fi.codecrew.moya.model.LanEvent;
import fi.codecrew.moya.utilities.SearchResult;
import fi.codecrew.moya.utilities.jpa.FacadeCallback;

@Stateless
@LocalBean
public class BillFacade extends IntegerPkGenericFacade<Bill> {

	@EJB
	private EventBeanLocal eventbean;

	public BillFacade() {
		super(Bill.class);

	}

	public Integer getBiggestBillNumber() {
		// SELECT max(b.billNumber) from Bill b where b.event = :event
		CriteriaBuilder cb = getEm().getCriteriaBuilder();
		CriteriaQuery<Integer> cq = cb.createQuery(Integer.class);
		Root<Bill> root = cq.from(Bill.class);
		cq.select(cb.max(root.get(Bill_.billNumber)));

		cq.where(cb.equal(root.get(Bill_.event), eventbean.getCurrentEvent()));

		return getSingleNullableResult(getEm().createQuery(cq));
	}

	public List<Bill> findAll() {
		CriteriaBuilder cb = getEm().getCriteriaBuilder();
		CriteriaQuery<Bill> cq = cb.createQuery(Bill.class);
		Root<Bill> root = cq.from(Bill.class);
		cq.where(cb.equal(root.get(Bill_.event), eventbean.getCurrentEvent()));
		cq.orderBy(cb.desc(root.get(Bill_.id)));
		return getEm().createQuery(cq).getResultList();
	}

	public List<Bill> find(EventUser user) {
		CriteriaBuilder cb = getEm().getCriteriaBuilder();
		CriteriaQuery<Bill> cq = cb.createQuery(Bill.class);
		Root<Bill> root = cq.from(Bill.class);
		cq.where(cb.equal(root.get(Bill_.event), eventbean.getCurrentEvent()),
				cb.equal(root.get(Bill_.user), user)
				);
		return getEm().createQuery(cq).getResultList();

	}

	public SearchResult<Bill> find(BillSearchQuery queryParams) {

		LanEvent event = eventbean.getCurrentEvent();
		List<FacadeCallback<Bill>> callbacks = new ArrayList<>();
		
		callbacks.add(new BillEventPredicate(event));
		callbacks.add(new BillFilterPredicate(event, queryParams.getFilters()));
		callbacks.add(new BillOrderPredicate(queryParams));
		callbacks.add(new BillUserPredicate(queryParams.getUser()));
		
		return super.searcher(queryParams, callbacks);
	}

}