package fi.otavanopisto.muikku.plugins.guidancerequest;
import java.util.Date;
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.guidancerequest.WorkspaceGuidanceRequest_;
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.guidancerequest.WorkspaceGuidanceRequest;
public class WorkspaceGuidanceRequestDAO extends CorePluginsDAO<WorkspaceGuidanceRequest> {
private static final long serialVersionUID = -8561225819989957176L;
public WorkspaceGuidanceRequest create(WorkspaceEntity workspaceEntity, UserEntity student, Date date, String message) {
WorkspaceGuidanceRequest assessmentRequest = new WorkspaceGuidanceRequest();
assessmentRequest.setWorkspace(workspaceEntity.getId());
assessmentRequest.setStudent(student.getId());
assessmentRequest.setDate(date);
assessmentRequest.setMessage(message);
getEntityManager().persist(assessmentRequest);
return assessmentRequest;
}
public List<WorkspaceGuidanceRequest> listByWorkspace(WorkspaceEntity workspaceEntity) {
EntityManager entityManager = getEntityManager();
CriteriaBuilder criteriaBuilder = entityManager.getCriteriaBuilder();
CriteriaQuery<WorkspaceGuidanceRequest> criteria = criteriaBuilder.createQuery(WorkspaceGuidanceRequest.class);
Root<WorkspaceGuidanceRequest> root = criteria.from(WorkspaceGuidanceRequest.class);
criteria.select(root);
criteria.where(criteriaBuilder.equal(root.get(WorkspaceGuidanceRequest_.workspace), workspaceEntity.getId()));
return entityManager.createQuery(criteria).getResultList();
}
public List<WorkspaceGuidanceRequest> listByWorkspaceAndUser(WorkspaceEntity workspaceEntity, UserEntity userEntity) {
EntityManager entityManager = getEntityManager();
CriteriaBuilder criteriaBuilder = entityManager.getCriteriaBuilder();
CriteriaQuery<WorkspaceGuidanceRequest> criteria = criteriaBuilder.createQuery(WorkspaceGuidanceRequest.class);
Root<WorkspaceGuidanceRequest> root = criteria.from(WorkspaceGuidanceRequest.class);
criteria.select(root);
criteria.where(
criteriaBuilder.and(
criteriaBuilder.equal(root.get(WorkspaceGuidanceRequest_.workspace), workspaceEntity.getId()),
criteriaBuilder.equal(root.get(WorkspaceGuidanceRequest_.student), userEntity.getId())
)
);
return entityManager.createQuery(criteria).getResultList();
}
}