package fi.otavanopisto.muikku.plugins.announcer.dao;
import java.util.List;
import java.util.stream.Collectors;
import javax.persistence.EntityManager;
import javax.persistence.criteria.CriteriaBuilder;
import javax.persistence.criteria.CriteriaQuery;
import javax.persistence.criteria.Root;
import org.apache.commons.collections.CollectionUtils;
import fi.otavanopisto.muikku.model.workspace.WorkspaceEntity;
import fi.otavanopisto.muikku.plugins.CorePluginsDAO;
import fi.otavanopisto.muikku.plugins.announcer.model.Announcement;
import fi.otavanopisto.muikku.plugins.announcer.workspace.model.AnnouncementWorkspace;
import fi.otavanopisto.muikku.plugins.announcer.workspace.model.AnnouncementWorkspace_;
public class AnnouncementWorkspaceDAO extends CorePluginsDAO<AnnouncementWorkspace> {
private static final long serialVersionUID = -9179843785232941193L;
public AnnouncementWorkspace create(Announcement announcement, Long workspaceEntityId, Boolean archived) {
AnnouncementWorkspace announcemenWorkspace = new AnnouncementWorkspace();
announcemenWorkspace.setAnnouncement(announcement);
announcemenWorkspace.setWorkspaceEntityId(workspaceEntityId);
announcemenWorkspace.setArchived(archived);
return persist(announcemenWorkspace);
}
public List<AnnouncementWorkspace> listByArchived(Boolean archived){
EntityManager entityManager = getEntityManager();
CriteriaBuilder criteriaBuilder = entityManager.getCriteriaBuilder();
CriteriaQuery<AnnouncementWorkspace> criteria = criteriaBuilder.createQuery(AnnouncementWorkspace.class);
Root<AnnouncementWorkspace> root = criteria.from(AnnouncementWorkspace.class);
criteria.select(root);
criteria.where(criteriaBuilder.equal(root.get(AnnouncementWorkspace_.archived), archived));
return entityManager.createQuery(criteria).getResultList();
}
public List<AnnouncementWorkspace> listByAnnouncementAndArchived(Announcement announcement, Boolean archived) {
EntityManager entityManager = getEntityManager();
CriteriaBuilder criteriaBuilder = entityManager.getCriteriaBuilder();
CriteriaQuery<AnnouncementWorkspace> criteria = criteriaBuilder.createQuery(AnnouncementWorkspace.class);
Root<AnnouncementWorkspace> root = criteria.from(AnnouncementWorkspace.class);
criteria.select(root);
criteria.where(
criteriaBuilder.and(
criteriaBuilder.equal(root.get(AnnouncementWorkspace_.announcement), announcement),
criteriaBuilder.equal(root.get(AnnouncementWorkspace_.archived), archived)
)
);
return entityManager.createQuery(criteria).getResultList();
}
public List<AnnouncementWorkspace> listByAnnouncementAndWorkspacesAndArchived(Announcement announcement, List<WorkspaceEntity> workspaces, Boolean archived) {
if (CollectionUtils.isEmpty(workspaces)) {
return listByAnnouncementAndArchived(announcement, archived);
}
List<Long> workspaceEntityIds = workspaces.stream().map((WorkspaceEntity workspace) -> workspace.getId()).collect(Collectors.toList());
EntityManager entityManager = getEntityManager();
CriteriaBuilder criteriaBuilder = entityManager.getCriteriaBuilder();
CriteriaQuery<AnnouncementWorkspace> criteria = criteriaBuilder.createQuery(AnnouncementWorkspace.class);
Root<AnnouncementWorkspace> root = criteria.from(AnnouncementWorkspace.class);
criteria.select(root);
criteria.where(
criteriaBuilder.and(
criteriaBuilder.equal(root.get(AnnouncementWorkspace_.announcement), announcement),
root.get(AnnouncementWorkspace_.workspaceEntityId).in(workspaceEntityIds),
criteriaBuilder.equal(root.get(AnnouncementWorkspace_.archived), archived)
)
);
return entityManager.createQuery(criteria).getResultList();
}
public AnnouncementWorkspace updateArchived(AnnouncementWorkspace announcementWorkspace, Boolean archived) {
announcementWorkspace.setArchived(archived);
return persist(announcementWorkspace);
}
public void delete(AnnouncementWorkspace announcementWorkspace){
super.delete(announcementWorkspace);
}
}