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.WorkspaceMaterialOrganizerFieldAnswer_;
import fi.otavanopisto.muikku.plugins.workspace.model.WorkspaceMaterialReply;
public class WorkspaceMaterialOrganizerFieldAnswerDAO extends CorePluginsDAO<WorkspaceMaterialOrganizerFieldAnswer> {
private static final long serialVersionUID = -7592424516902940440L;
public WorkspaceMaterialOrganizerFieldAnswer create(WorkspaceMaterialField field, WorkspaceMaterialReply reply, String value) {
WorkspaceMaterialOrganizerFieldAnswer workspaceMaterialOrganizerFieldAnswer = new WorkspaceMaterialOrganizerFieldAnswer();
workspaceMaterialOrganizerFieldAnswer.setField(field);
workspaceMaterialOrganizerFieldAnswer.setReply(reply);
workspaceMaterialOrganizerFieldAnswer.setValue(value);
return persist(workspaceMaterialOrganizerFieldAnswer);
}
public WorkspaceMaterialOrganizerFieldAnswer findByFieldAndReply(WorkspaceMaterialField field, WorkspaceMaterialReply reply) {
EntityManager entityManager = getEntityManager();
CriteriaBuilder criteriaBuilder = entityManager.getCriteriaBuilder();
CriteriaQuery<WorkspaceMaterialOrganizerFieldAnswer> criteria = criteriaBuilder.createQuery(WorkspaceMaterialOrganizerFieldAnswer.class);
Root<WorkspaceMaterialOrganizerFieldAnswer> root = criteria.from(WorkspaceMaterialOrganizerFieldAnswer.class);
criteria.select(root);
criteria.where(
criteriaBuilder.and(
criteriaBuilder.equal(root.get(WorkspaceMaterialOrganizerFieldAnswer_.field), field),
criteriaBuilder.equal(root.get(WorkspaceMaterialOrganizerFieldAnswer_.reply), reply)
)
);
return getSingleResult(entityManager.createQuery(criteria));
}
public List<WorkspaceMaterialOrganizerFieldAnswer> listByWorkspaceMaterialField(WorkspaceMaterialField field) {
EntityManager entityManager = getEntityManager();
CriteriaBuilder criteriaBuilder = entityManager.getCriteriaBuilder();
CriteriaQuery<WorkspaceMaterialOrganizerFieldAnswer> criteria = criteriaBuilder.createQuery(WorkspaceMaterialOrganizerFieldAnswer.class);
Root<WorkspaceMaterialOrganizerFieldAnswer> root = criteria.from(WorkspaceMaterialOrganizerFieldAnswer.class);
criteria.select(root);
criteria.where(
criteriaBuilder.equal(root.get(WorkspaceMaterialOrganizerFieldAnswer_.field), field)
);
return entityManager.createQuery(criteria).getResultList();
}
public WorkspaceMaterialOrganizerFieldAnswer updateValue(WorkspaceMaterialOrganizerFieldAnswer workspaceMaterialOrganizerFieldAnswer, String value) {
workspaceMaterialOrganizerFieldAnswer.setValue(value);
return persist(workspaceMaterialOrganizerFieldAnswer);
}
}