package fi.otavanopisto.muikku.plugins.forum.wall;
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.forum.wall.ForumAreaSubscription_;
import fi.otavanopisto.muikku.model.users.UserEntity;
import fi.otavanopisto.muikku.plugins.CorePluginsDAO;
import fi.otavanopisto.muikku.plugins.forum.model.ForumArea;
import fi.otavanopisto.muikku.plugins.forum.wall.ForumAreaSubscription;
public class ForumAreaSubscriptionDAO extends CorePluginsDAO<ForumAreaSubscription> {
private static final long serialVersionUID = 2496199219925814980L;
public ForumAreaSubscription create(UserEntity user, ForumArea forumArea) {
ForumAreaSubscription forumSubscription = new ForumAreaSubscription();
forumSubscription.setUser(user.getId());
forumSubscription.setForumArea(forumArea);
getEntityManager().persist(forumSubscription);
return forumSubscription;
}
public List<ForumAreaSubscription> listByUser(UserEntity user) {
EntityManager entityManager = getEntityManager();
CriteriaBuilder criteriaBuilder = entityManager.getCriteriaBuilder();
CriteriaQuery<ForumAreaSubscription> criteria = criteriaBuilder.createQuery(ForumAreaSubscription.class);
Root<ForumAreaSubscription> root = criteria.from(ForumAreaSubscription.class);
criteria.select(root);
criteria.where(criteriaBuilder.equal(root.get(ForumAreaSubscription_.user), user.getId()));
return entityManager.createQuery(criteria).getResultList();
}
public ForumAreaSubscription findByUserAndForumArea(UserEntity user, ForumArea forumArea) {
EntityManager entityManager = getEntityManager();
CriteriaBuilder criteriaBuilder = entityManager.getCriteriaBuilder();
CriteriaQuery<ForumAreaSubscription> criteria = criteriaBuilder.createQuery(ForumAreaSubscription.class);
Root<ForumAreaSubscription> root = criteria.from(ForumAreaSubscription.class);
criteria.select(root);
criteria.where(
criteriaBuilder.and(
criteriaBuilder.equal(root.get(ForumAreaSubscription_.user), user.getId()),
criteriaBuilder.equal(root.get(ForumAreaSubscription_.forumArea), forumArea)
)
);
return getSingleResult(entityManager.createQuery(criteria));
}
}