package fi.otavanopisto.muikku.dao.oauth; import java.util.List; import fi.otavanopisto.muikku.model.oauth.ConsumerPermission_; import fi.otavanopisto.muikku.dao.CoreDAO; import fi.otavanopisto.muikku.model.oauth.Consumer; import fi.otavanopisto.muikku.model.oauth.ConsumerPermission; import javax.persistence.EntityManager; import javax.persistence.criteria.CriteriaBuilder; import javax.persistence.criteria.CriteriaQuery; import javax.persistence.criteria.Root; public class ConsumerPermissionDAO extends CoreDAO<ConsumerPermission> { private static final long serialVersionUID = 2260087590243069907L; public ConsumerPermission create(Consumer consumer, String permission) { ConsumerPermission consumerPermission = new ConsumerPermission(); consumerPermission.setConsumer(consumer); consumerPermission.setPermission(permission); getEntityManager().persist(consumerPermission); return consumerPermission; } public ConsumerPermission findByConsumerAndPermission(Consumer consumer, String permission) { EntityManager entityManager = getEntityManager(); CriteriaBuilder criteriaBuilder = entityManager.getCriteriaBuilder(); CriteriaQuery<ConsumerPermission> criteria = criteriaBuilder.createQuery(ConsumerPermission.class); Root<ConsumerPermission> root = criteria.from(ConsumerPermission.class); criteria.select(root); criteria.where( criteriaBuilder.and( criteriaBuilder.equal(root.get(ConsumerPermission_.consumer), consumer), criteriaBuilder.equal(root.get(ConsumerPermission_.permission), permission) ) ); return getSingleResult(entityManager.createQuery(criteria)); } public List<ConsumerPermission> listByConsumer(Consumer consumer) { EntityManager entityManager = getEntityManager(); CriteriaBuilder criteriaBuilder = entityManager.getCriteriaBuilder(); CriteriaQuery<ConsumerPermission> criteria = criteriaBuilder.createQuery(ConsumerPermission.class); Root<ConsumerPermission> root = criteria.from(ConsumerPermission.class); criteria.select(root); criteria.where(criteriaBuilder.equal(root.get(ConsumerPermission_.consumer), consumer)); return entityManager.createQuery(criteria).getResultList(); } public List<ConsumerPermission> listByConsumerAndPermissionNotIn(Consumer consumer, List<String> permissions) { EntityManager entityManager = getEntityManager(); CriteriaBuilder criteriaBuilder = entityManager.getCriteriaBuilder(); CriteriaQuery<ConsumerPermission> criteria = criteriaBuilder.createQuery(ConsumerPermission.class); Root<ConsumerPermission> root = criteria.from(ConsumerPermission.class); criteria.select(root); criteria.where( criteriaBuilder.and( criteriaBuilder.equal(root.get(ConsumerPermission_.consumer), consumer), criteriaBuilder.not(root.get(ConsumerPermission_.permission).in(permissions)) ) ); return entityManager.createQuery(criteria).getResultList(); } public void delete(ConsumerPermission consumerScope) { super.delete(consumerScope); } }