package fi.otavanopisto.muikku.plugins.workspace.dao; import java.util.List; import javax.persistence.EntityManager; import javax.persistence.criteria.CriteriaBuilder; import javax.persistence.criteria.CriteriaQuery; import javax.persistence.criteria.Root; import fi.otavanopisto.muikku.plugins.CorePluginsDAO; import fi.otavanopisto.muikku.plugins.workspace.model.WorkspaceMaterialField; import fi.otavanopisto.muikku.plugins.workspace.model.WorkspaceMaterialOrganizerFieldAnswer_; import fi.otavanopisto.muikku.plugins.workspace.model.WorkspaceMaterialReply; import fi.otavanopisto.muikku.plugins.workspace.model.WorkspaceMaterialSorterFieldAnswer; import fi.otavanopisto.muikku.plugins.workspace.model.WorkspaceMaterialSorterFieldAnswer_; public class WorkspaceMaterialSorterFieldAnswerDAO extends CorePluginsDAO<WorkspaceMaterialSorterFieldAnswer> { private static final long serialVersionUID = 1984922833954027686L; public WorkspaceMaterialSorterFieldAnswer create(WorkspaceMaterialField field, WorkspaceMaterialReply reply, String value) { WorkspaceMaterialSorterFieldAnswer workspaceMaterialSorterFieldAnswer = new WorkspaceMaterialSorterFieldAnswer(); workspaceMaterialSorterFieldAnswer.setField(field); workspaceMaterialSorterFieldAnswer.setReply(reply); workspaceMaterialSorterFieldAnswer.setValue(value); return persist(workspaceMaterialSorterFieldAnswer); } public WorkspaceMaterialSorterFieldAnswer findByFieldAndReply(WorkspaceMaterialField field, WorkspaceMaterialReply reply) { EntityManager entityManager = getEntityManager(); CriteriaBuilder criteriaBuilder = entityManager.getCriteriaBuilder(); CriteriaQuery<WorkspaceMaterialSorterFieldAnswer> criteria = criteriaBuilder.createQuery(WorkspaceMaterialSorterFieldAnswer.class); Root<WorkspaceMaterialSorterFieldAnswer> root = criteria.from(WorkspaceMaterialSorterFieldAnswer.class); criteria.select(root); criteria.where( criteriaBuilder.and( criteriaBuilder.equal(root.get(WorkspaceMaterialSorterFieldAnswer_.field), field), criteriaBuilder.equal(root.get(WorkspaceMaterialSorterFieldAnswer_.reply), reply) ) ); return getSingleResult(entityManager.createQuery(criteria)); } public List<WorkspaceMaterialSorterFieldAnswer> listByWorkspaceMaterialField(WorkspaceMaterialField field) { EntityManager entityManager = getEntityManager(); CriteriaBuilder criteriaBuilder = entityManager.getCriteriaBuilder(); CriteriaQuery<WorkspaceMaterialSorterFieldAnswer> criteria = criteriaBuilder.createQuery(WorkspaceMaterialSorterFieldAnswer.class); Root<WorkspaceMaterialSorterFieldAnswer> root = criteria.from(WorkspaceMaterialSorterFieldAnswer.class); criteria.select(root); criteria.where( criteriaBuilder.equal(root.get(WorkspaceMaterialOrganizerFieldAnswer_.field), field) ); return entityManager.createQuery(criteria).getResultList(); } public WorkspaceMaterialSorterFieldAnswer updateValue(WorkspaceMaterialSorterFieldAnswer workspaceMaterialSorterFieldAnswer, String value) { workspaceMaterialSorterFieldAnswer.setValue(value); return persist(workspaceMaterialSorterFieldAnswer); } }