package fi.otavanopisto.pyramus.dao.courses;
import java.util.List;
import javax.ejb.Stateless;
import javax.persistence.EntityManager;
import javax.persistence.criteria.CriteriaBuilder;
import javax.persistence.criteria.CriteriaQuery;
import javax.persistence.criteria.Root;
import fi.otavanopisto.pyramus.dao.PyramusEntityDAO;
import fi.otavanopisto.pyramus.domainmodel.base.VariableType;
import fi.otavanopisto.pyramus.domainmodel.courses.CourseStudentVariableKey;
import fi.otavanopisto.pyramus.domainmodel.courses.CourseStudentVariableKey_;
@Stateless
public class CourseStudentVariableKeyDAO extends PyramusEntityDAO<CourseStudentVariableKey> {
public CourseStudentVariableKey create(boolean userEditable, String variableKey, String variableName, VariableType variableType) {
EntityManager entityManager = getEntityManager();
CourseStudentVariableKey courseStudentVariableKey = new CourseStudentVariableKey();
courseStudentVariableKey.setUserEditable(userEditable);
courseStudentVariableKey.setVariableKey(variableKey);
courseStudentVariableKey.setVariableName(variableName);
courseStudentVariableKey.setVariableType(variableType);
entityManager.persist(courseStudentVariableKey);
return courseStudentVariableKey;
}
public CourseStudentVariableKey findByKey(String key) {
EntityManager entityManager = getEntityManager();
CriteriaBuilder criteriaBuilder = entityManager.getCriteriaBuilder();
CriteriaQuery<CourseStudentVariableKey> criteria = criteriaBuilder.createQuery(CourseStudentVariableKey.class);
Root<CourseStudentVariableKey> root = criteria.from(CourseStudentVariableKey.class);
criteria.select(root);
criteria.where(
criteriaBuilder.equal(root.get(CourseStudentVariableKey_.variableKey), key)
);
return getSingleResult(entityManager.createQuery(criteria));
}
/**
* Returns a list of user editable student variable keys from the database, sorted by their user interface name.
*
* @return A list of user editable student variable keys
*/
public List<CourseStudentVariableKey> listUserEditableCourseStudentVariableKeys() {
EntityManager entityManager = getEntityManager();
CriteriaBuilder criteriaBuilder = entityManager.getCriteriaBuilder();
CriteriaQuery<CourseStudentVariableKey> criteria = criteriaBuilder.createQuery(CourseStudentVariableKey.class);
Root<CourseStudentVariableKey> root = criteria.from(CourseStudentVariableKey.class);
criteria.select(root);
criteria.where(
criteriaBuilder.equal(root.get(CourseStudentVariableKey_.userEditable), Boolean.TRUE)
);
return entityManager.createQuery(criteria).getResultList();
}
}