package fi.otavanopisto.muikku.plugins.forum.dao; import java.util.List; import javax.persistence.EntityManager; import javax.persistence.TypedQuery; import javax.persistence.criteria.CriteriaBuilder; import javax.persistence.criteria.CriteriaQuery; import javax.persistence.criteria.Root; import fi.otavanopisto.muikku.plugins.forum.model.ForumMessage_; import fi.otavanopisto.muikku.plugins.forum.model.WorkspaceForumArea_; import fi.otavanopisto.muikku.model.users.UserEntity; import fi.otavanopisto.muikku.model.workspace.WorkspaceEntity; import fi.otavanopisto.muikku.plugins.CorePluginsDAO; import fi.otavanopisto.muikku.plugins.forum.model.ForumArea; import fi.otavanopisto.muikku.plugins.forum.model.ForumMessage; import fi.otavanopisto.muikku.plugins.forum.model.WorkspaceForumArea; public class ForumMessageDAO extends CorePluginsDAO<ForumMessage> { private static final long serialVersionUID = 9013247702204973018L; public List<ForumMessage> listByContributingUser(UserEntity loggedUser) { EntityManager entityManager = getEntityManager(); CriteriaBuilder criteriaBuilder = entityManager.getCriteriaBuilder(); CriteriaQuery<ForumMessage> criteria = criteriaBuilder.createQuery(ForumMessage.class); Root<ForumMessage> root = criteria.from(ForumMessage.class); criteria.select(root); criteria.where( criteriaBuilder.and( criteriaBuilder.equal(root.get(ForumMessage_.creator), loggedUser.getId()), criteriaBuilder.equal(root.get(ForumMessage_.archived), Boolean.FALSE) ) ); return entityManager.createQuery(criteria).getResultList(); } public List<ForumMessage> listByWorkspace(WorkspaceEntity workspace) { EntityManager entityManager = getEntityManager(); CriteriaBuilder criteriaBuilder = entityManager.getCriteriaBuilder(); CriteriaQuery<ForumMessage> criteria = criteriaBuilder.createQuery(ForumMessage.class); Root<ForumMessage> root = criteria.from(ForumMessage.class); Root<WorkspaceForumArea> root2 = criteria.from(WorkspaceForumArea.class); criteria.select(root); criteria.where( criteriaBuilder.and( criteriaBuilder.equal(root2.get(WorkspaceForumArea_.workspace), workspace.getId()), criteriaBuilder.equal(root2.get(WorkspaceForumArea_.id), root.get(ForumMessage_.forumArea)), criteriaBuilder.equal(root.get(ForumMessage_.archived), Boolean.FALSE) ) ); return entityManager.createQuery(criteria).getResultList(); } public Long countByWorkspaceEntityAndCreator(Long workspaceEntityId, Long creatorId) { EntityManager entityManager = getEntityManager(); CriteriaBuilder criteriaBuilder = entityManager.getCriteriaBuilder(); CriteriaQuery<Long> criteria = criteriaBuilder.createQuery(Long.class); Root<ForumMessage> root = criteria.from(ForumMessage.class); Root<WorkspaceForumArea> workspaceAreaJoin = criteria.from(WorkspaceForumArea.class); criteria.select(criteriaBuilder.count(root)); criteria.where( criteriaBuilder.and( criteriaBuilder.equal(workspaceAreaJoin.get(WorkspaceForumArea_.workspace), workspaceEntityId), criteriaBuilder.equal(workspaceAreaJoin.get(WorkspaceForumArea_.id), root.get(ForumMessage_.forumArea)), criteriaBuilder.equal(root.get(ForumMessage_.creator), creatorId), criteriaBuilder.equal(root.get(ForumMessage_.archived), Boolean.FALSE) ) ); return entityManager.createQuery(criteria).getSingleResult(); } public List<ForumMessage> listByWorkspaceEntityAndCreatorOrderByCreated(Long workspaceEntityId, Long creatorId, int firstResult, int maxResults) { EntityManager entityManager = getEntityManager(); CriteriaBuilder criteriaBuilder = entityManager.getCriteriaBuilder(); CriteriaQuery<ForumMessage> criteria = criteriaBuilder.createQuery(ForumMessage.class); Root<ForumMessage> root = criteria.from(ForumMessage.class); Root<WorkspaceForumArea> workspaceAreaJoin = criteria.from(WorkspaceForumArea.class); criteria.select(root); criteria.where( criteriaBuilder.and( criteriaBuilder.equal(workspaceAreaJoin.get(WorkspaceForumArea_.workspace), workspaceEntityId), criteriaBuilder.equal(workspaceAreaJoin.get(WorkspaceForumArea_.id), root.get(ForumMessage_.forumArea)), criteriaBuilder.equal(root.get(ForumMessage_.creator), creatorId), criteriaBuilder.equal(root.get(ForumMessage_.archived), Boolean.FALSE) ) ); criteria.orderBy(criteriaBuilder.desc(root.get(ForumMessage_.created))); TypedQuery<ForumMessage> query = entityManager.createQuery(criteria); query.setFirstResult(firstResult); query.setMaxResults(maxResults); return query.getResultList(); } public ForumMessage findLatestMessageByArea(ForumArea area) { EntityManager entityManager = getEntityManager(); CriteriaBuilder criteriaBuilder = entityManager.getCriteriaBuilder(); CriteriaQuery<ForumMessage> criteria = criteriaBuilder.createQuery(ForumMessage.class); Root<ForumMessage> root = criteria.from(ForumMessage.class); criteria.select(root); criteria.where( criteriaBuilder.and( criteriaBuilder.equal(root.get(ForumMessage_.forumArea), area), criteriaBuilder.equal(root.get(ForumMessage_.archived), Boolean.FALSE) ) ); criteria.orderBy(criteriaBuilder.desc(root.get(ForumMessage_.created))); TypedQuery<ForumMessage> query = entityManager.createQuery(criteria); query.setMaxResults(1); return getSingleResult(query); } public Long countByArea(ForumArea area) { EntityManager entityManager = getEntityManager(); CriteriaBuilder criteriaBuilder = entityManager.getCriteriaBuilder(); CriteriaQuery<Long> criteria = criteriaBuilder.createQuery(Long.class); Root<ForumMessage> root = criteria.from(ForumMessage.class); criteria.select(criteriaBuilder.count(root)); criteria.where( criteriaBuilder.and( criteriaBuilder.equal(root.get(ForumMessage_.forumArea), area), criteriaBuilder.equal(root.get(ForumMessage_.archived), Boolean.FALSE) ) ); return entityManager.createQuery(criteria).getSingleResult(); } public void archive(ForumMessage message) { message.setArchived(Boolean.TRUE); getEntityManager().persist(message); } }