da.RequestJpaController.java Source code

Java tutorial

Introduction

Here is the source code for da.RequestJpaController.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 da;

import com.google.common.collect.Lists;
import da.exceptions.NonexistentEntityException;
import da.exceptions.PreexistingEntityException;
import da.exceptions.RollbackFailureException;
import java.io.Serializable;
import javax.persistence.Query;
import javax.persistence.EntityNotFoundException;
import javax.persistence.criteria.CriteriaQuery;
import javax.persistence.criteria.Root;
import entity.Account;
import entity.Department;
import entity.Request;
import java.util.List;
import javax.persistence.EntityManager;
import javax.persistence.EntityManagerFactory;
import javax.persistence.TypedQuery;
import javax.transaction.UserTransaction;

/**
 *
 * @author The
 */
public class RequestJpaController implements Serializable {

    public RequestJpaController(UserTransaction utx, EntityManagerFactory emf) {
        this.utx = utx;
        this.emf = emf;
    }

    private UserTransaction utx = null;
    private EntityManagerFactory emf = null;

    public EntityManager getEntityManager() {
        return emf.createEntityManager();
    }

    public List<Request> getRequestsByResolver(String username, int type) {
        TypedQuery<Request> query = getEntityManager().createQuery(
                "SELECT r FROM Request r WHERE r.resolveAccount.username = :username AND r.type=:type  ORDER BY r.time DESC",
                Request.class);
        query.setParameter("username", username);
        query.setParameter("type", type);
        return Lists.reverse(query.getResultList());
    }

    public List<Request> getRequestsByResolver(String username, int status, int type) {
        TypedQuery<Request> query = getEntityManager().createQuery(
                "SELECT r FROM Request r WHERE r.resolveAccount.username = :username AND r.type=:type AND r.status=:status ORDER BY r.time DESC",
                Request.class);
        query.setParameter("username", username);
        query.setParameter("type", type);
        query.setParameter("status", status);
        return Lists.reverse(query.getResultList());
    }

    public List<Request> getRequests(String username, int type, int status) {
        TypedQuery<Request> query = getEntityManager().createQuery(
                "SELECT r FROM Request r WHERE r.requestAccount.username = :username AND r.type=:type AND r.status=:status ORDER BY r.time DESC",
                Request.class);
        query.setParameter("username", username);
        query.setParameter("type", type);
        query.setParameter("status", status);
        return Lists.reverse(query.getResultList());
    }

    public List<Request> getRequests(int type) {
        TypedQuery<Request> query = getEntityManager()
                .createQuery("SELECT r FROM Request r WHERE r.type=:type ORDER BY r.time DESC", Request.class);
        query.setParameter("type", type);
        return Lists.reverse(query.getResultList());
    }

    public List<Request> getRequestsByStatus(int status, int type) {
        TypedQuery<Request> query = getEntityManager().createQuery(
                "SELECT r FROM Request r WHERE r.status=:status AND r.type=:type  ORDER BY r.time DESC",
                Request.class);
        query.setParameter("type", type);
        query.setParameter("status", status);
        return query.getResultList();
    }

    public List<Request> getAllComplaintOfOneDepartment(Department departmentId) {
        TypedQuery<Request> query = getEntityManager().createQuery(
                "SELECT r FROM Request r WHERE r.type=2 AND r.requestAccount.departmentId = :departmentId",
                Request.class);
        query.setParameter("departmentId", departmentId);
        List<Request> result = query.getResultList();
        if (result.isEmpty()) {
            return null;
        } else {
            return result;
        }
    }

    public void create(Request request) throws PreexistingEntityException, RollbackFailureException, Exception {
        EntityManager em = null;
        try {
            utx.begin();
            em = getEntityManager();
            Account resolveAccount = request.getResolveAccount();
            if (resolveAccount != null) {
                resolveAccount = em.getReference(resolveAccount.getClass(), resolveAccount.getUsername());
                request.setResolveAccount(resolveAccount);
            }
            Account requestAccount = request.getRequestAccount();
            if (requestAccount != null) {
                requestAccount = em.getReference(requestAccount.getClass(), requestAccount.getUsername());
                request.setRequestAccount(requestAccount);
            }
            em.persist(request);
            if (resolveAccount != null) {
                resolveAccount.getRequestList().add(request);
                resolveAccount = em.merge(resolveAccount);
            }
            if (requestAccount != null) {
                requestAccount.getRequestList().add(request);
                requestAccount = em.merge(requestAccount);
            }
            utx.commit();
        } catch (Exception ex) {
            try {
                utx.rollback();
            } catch (Exception re) {
                throw new RollbackFailureException("An error occurred attempting to roll back the transaction.",
                        re);
            }
            throw ex;
        } finally {
            if (em != null) {
                em.close();
            }
        }
    }

    public void edit(Request request) throws NonexistentEntityException, RollbackFailureException, Exception {
        EntityManager em = null;
        try {
            utx.begin();
            em = getEntityManager();
            Request persistentRequest = em.find(Request.class, request.getId());
            Account resolveAccountOld = persistentRequest.getResolveAccount();
            Account resolveAccountNew = request.getResolveAccount();
            Account requestAccountOld = persistentRequest.getRequestAccount();
            Account requestAccountNew = request.getRequestAccount();
            if (resolveAccountNew != null) {
                resolveAccountNew = em.getReference(resolveAccountNew.getClass(), resolveAccountNew.getUsername());
                request.setResolveAccount(resolveAccountNew);
            }
            if (requestAccountNew != null) {
                requestAccountNew = em.getReference(requestAccountNew.getClass(), requestAccountNew.getUsername());
                request.setRequestAccount(requestAccountNew);
            }
            request = em.merge(request);
            if (resolveAccountOld != null && !resolveAccountOld.equals(resolveAccountNew)) {
                resolveAccountOld.getRequestList().remove(request);
                resolveAccountOld = em.merge(resolveAccountOld);
            }
            if (resolveAccountNew != null && !resolveAccountNew.equals(resolveAccountOld)) {
                resolveAccountNew.getRequestList().add(request);
                resolveAccountNew = em.merge(resolveAccountNew);
            }
            if (requestAccountOld != null && !requestAccountOld.equals(requestAccountNew)) {
                requestAccountOld.getRequestList().remove(request);
                requestAccountOld = em.merge(requestAccountOld);
            }
            if (requestAccountNew != null && !requestAccountNew.equals(requestAccountOld)) {
                requestAccountNew.getRequestList().add(request);
                requestAccountNew = em.merge(requestAccountNew);
            }
            utx.commit();
        } catch (Exception ex) {
            try {
                utx.rollback();
            } catch (Exception re) {
                throw new RollbackFailureException("An error occurred attempting to roll back the transaction.",
                        re);
            }
            String msg = ex.getLocalizedMessage();
            if (msg == null || msg.length() == 0) {
                Integer id = request.getId();
                if (findRequest(id) == null) {
                    throw new NonexistentEntityException("The request with id " + id + " no longer exists.");
                }
            }
            throw ex;
        } finally {
            if (em != null) {
                em.close();
            }
        }
    }

    public void destroy(Integer id) throws NonexistentEntityException, RollbackFailureException, Exception {
        EntityManager em = null;
        try {
            utx.begin();
            em = getEntityManager();
            Request request;
            try {
                request = em.getReference(Request.class, id);
                request.getId();
            } catch (EntityNotFoundException enfe) {
                throw new NonexistentEntityException("The request with id " + id + " no longer exists.", enfe);
            }
            Account resolveAccount = request.getResolveAccount();
            if (resolveAccount != null) {
                resolveAccount.getRequestList().remove(request);
                resolveAccount = em.merge(resolveAccount);
            }
            Account requestAccount = request.getRequestAccount();
            if (requestAccount != null) {
                requestAccount.getRequestList().remove(request);
                requestAccount = em.merge(requestAccount);
            }
            em.remove(request);
            utx.commit();
        } catch (Exception ex) {
            try {
                utx.rollback();
            } catch (Exception re) {
                throw new RollbackFailureException("An error occurred attempting to roll back the transaction.",
                        re);
            }
            throw ex;
        } finally {
            if (em != null) {
                em.close();
            }
        }
    }

    public List<Request> findRequestEntities() {
        return findRequestEntities(true, -1, -1);
    }

    public List<Request> findRequestEntities(int maxResults, int firstResult) {
        return findRequestEntities(false, maxResults, firstResult);
    }

    private List<Request> findRequestEntities(boolean all, int maxResults, int firstResult) {
        EntityManager em = getEntityManager();
        try {
            CriteriaQuery cq = em.getCriteriaBuilder().createQuery();
            cq.select(cq.from(Request.class));
            Query q = em.createQuery(cq);
            if (!all) {
                q.setMaxResults(maxResults);
                q.setFirstResult(firstResult);
            }
            return q.getResultList();
        } finally {
            em.close();
        }
    }

    public Request findRequest(Integer id) {
        EntityManager em = getEntityManager();
        try {
            return em.find(Request.class, id);
        } finally {
            em.close();
        }
    }

    public int getRequestCount() {
        EntityManager em = getEntityManager();
        try {
            CriteriaQuery cq = em.getCriteriaBuilder().createQuery();
            Root<Request> rt = cq.from(Request.class);
            cq.select(em.getCriteriaBuilder().count(rt));
            Query q = em.createQuery(cq);
            return ((Long) q.getSingleResult()).intValue();
        } finally {
            em.close();
        }
    }

}