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