package fi.otavanopisto.muikku.plugins.schooldatalocal.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.schooldatalocal.model.LocalUserPropertyKey_;
import fi.otavanopisto.muikku.plugins.CorePluginsDAO;
import fi.otavanopisto.muikku.plugins.schooldatalocal.model.LocalUserPropertyKey;
public class LocalUserPropertyKeyDAO extends CorePluginsDAO<LocalUserPropertyKey> {
private static final long serialVersionUID = 4968036949533696238L;
public LocalUserPropertyKey create(String name, Boolean archived) {
LocalUserPropertyKey localUserPropertyKey = new LocalUserPropertyKey();
localUserPropertyKey.setName(name);
localUserPropertyKey.setArchived(archived);
return persist(localUserPropertyKey);
}
public LocalUserPropertyKey findByNameAndArchived(String name, Boolean archived) {
EntityManager entityManager = getEntityManager();
CriteriaBuilder criteriaBuilder = entityManager.getCriteriaBuilder();
CriteriaQuery<LocalUserPropertyKey> criteria = criteriaBuilder.createQuery(LocalUserPropertyKey.class);
Root<LocalUserPropertyKey> root = criteria.from(LocalUserPropertyKey.class);
criteria.select(root);
criteria.where(
criteriaBuilder.and(
criteriaBuilder.equal(root.get(LocalUserPropertyKey_.name), name),
criteriaBuilder.equal(root.get(LocalUserPropertyKey_.archived), archived)
)
);
return getSingleResult(entityManager.createQuery(criteria));
}
public List<LocalUserPropertyKey> listByArchived(Boolean archived) {
EntityManager entityManager = getEntityManager();
CriteriaBuilder criteriaBuilder = entityManager.getCriteriaBuilder();
CriteriaQuery<LocalUserPropertyKey> criteria = criteriaBuilder.createQuery(LocalUserPropertyKey.class);
Root<LocalUserPropertyKey> root = criteria.from(LocalUserPropertyKey.class);
criteria.select(root);
criteria.where(
criteriaBuilder.and(
criteriaBuilder.equal(root.get(LocalUserPropertyKey_.archived), archived)
)
);
return entityManager.createQuery(criteria).getResultList();
}
}