package fi.otavanopisto.pyramus.dao.base;
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.SchoolVariableKey;
import fi.otavanopisto.pyramus.domainmodel.base.VariableType;
import fi.otavanopisto.pyramus.domainmodel.base.SchoolVariableKey_;
@Stateless
public class SchoolVariableKeyDAO extends PyramusEntityDAO<SchoolVariableKey> {
public SchoolVariableKey create(String variableKey, String variableName, VariableType variableType, Boolean userEditable) {
SchoolVariableKey schoolVariableKey = new SchoolVariableKey();
schoolVariableKey.setUserEditable(userEditable);
schoolVariableKey.setVariableKey(variableKey);
schoolVariableKey.setVariableName(variableName);
schoolVariableKey.setVariableType(variableType);
return persist(schoolVariableKey);
}
public SchoolVariableKey findVariableKey(String key) {
EntityManager entityManager = getEntityManager();
CriteriaBuilder criteriaBuilder = entityManager.getCriteriaBuilder();
CriteriaQuery<SchoolVariableKey> criteria = criteriaBuilder.createQuery(SchoolVariableKey.class);
Root<SchoolVariableKey> root = criteria.from(SchoolVariableKey.class);
criteria.select(root);
criteria.where(
criteriaBuilder.equal(root.get(SchoolVariableKey_.variableKey), key)
);
return getSingleResult(entityManager.createQuery(criteria));
}
/**
* Returns a list of user editable school variable keys from the database, sorted by their user interface name.
*
* @return A list of user editable school variable keys
*/
public List<SchoolVariableKey> listUserEditableVariableKeys() {
EntityManager entityManager = getEntityManager();
CriteriaBuilder criteriaBuilder = entityManager.getCriteriaBuilder();
CriteriaQuery<SchoolVariableKey> criteria = criteriaBuilder.createQuery(SchoolVariableKey.class);
Root<SchoolVariableKey> root = criteria.from(SchoolVariableKey.class);
criteria.select(root);
criteria.where(
criteriaBuilder.equal(root.get(SchoolVariableKey_.userEditable), Boolean.TRUE)
);
return entityManager.createQuery(criteria).getResultList();
}
public SchoolVariableKey updateUserEditable(SchoolVariableKey schoolVariableKey, Boolean userEditable) {
schoolVariableKey.setUserEditable(userEditable);
return persist(schoolVariableKey);
}
public SchoolVariableKey updateVariableName(SchoolVariableKey schoolVariableKey, String variableName) {
schoolVariableKey.setVariableName(variableName);
return persist(schoolVariableKey);
}
public SchoolVariableKey updateVariableType(SchoolVariableKey schoolVariableKey, VariableType variableType) {
schoolVariableKey.setVariableType(variableType);
return persist(schoolVariableKey);
}
}