package fi.otavanopisto.muikku.dao.users;
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.dao.CoreDAO;
import fi.otavanopisto.muikku.model.users.Flag;
import fi.otavanopisto.muikku.model.users.FlagShare;
import fi.otavanopisto.muikku.model.users.FlagShare_;
import fi.otavanopisto.muikku.model.users.UserSchoolDataIdentifier;
public class FlagShareDAO extends CoreDAO<FlagShare> {
private static final long serialVersionUID = 1350239315051902573L;
public FlagShare create(Flag flag, UserSchoolDataIdentifier userIdentifier) {
FlagShare flagShare = new FlagShare();
flagShare.setFlag(flag);
flagShare.setUserIdentifier(userIdentifier);
return persist(flagShare);
}
public FlagShare findByFlagAndUserIdentifier(Flag flag, UserSchoolDataIdentifier userIdentifier) {
EntityManager entityManager = getEntityManager();
CriteriaBuilder criteriaBuilder = entityManager.getCriteriaBuilder();
CriteriaQuery<FlagShare> criteria = criteriaBuilder.createQuery(FlagShare.class);
Root<FlagShare> root = criteria.from(FlagShare.class);
criteria.select(root);
criteria.where(
criteriaBuilder.equal(root.get(FlagShare_.flag), flag),
criteriaBuilder.equal(root.get(FlagShare_.userIdentifier), userIdentifier)
);
return getSingleResult(entityManager.createQuery(criteria));
}
public List<FlagShare> listByFlag(Flag flag) {
EntityManager entityManager = getEntityManager();
CriteriaBuilder criteriaBuilder = entityManager.getCriteriaBuilder();
CriteriaQuery<FlagShare> criteria = criteriaBuilder.createQuery(FlagShare.class);
Root<FlagShare> root = criteria.from(FlagShare.class);
criteria.select(root);
criteria.where(
criteriaBuilder.equal(root.get(FlagShare_.flag), flag)
);
return entityManager.createQuery(criteria).getResultList();
}
public List<FlagShare> listByUserIdentifier(UserSchoolDataIdentifier userIdentifier) {
EntityManager entityManager = getEntityManager();
CriteriaBuilder criteriaBuilder = entityManager.getCriteriaBuilder();
CriteriaQuery<FlagShare> criteria = criteriaBuilder.createQuery(FlagShare.class);
Root<FlagShare> root = criteria.from(FlagShare.class);
criteria.select(root);
criteria.where(
criteriaBuilder.equal(root.get(FlagShare_.userIdentifier), userIdentifier)
);
return entityManager.createQuery(criteria).getResultList();
}
public List<Flag> listFlagsByUserIdentifier(UserSchoolDataIdentifier userIdentifier) {
EntityManager entityManager = getEntityManager();
CriteriaBuilder criteriaBuilder = entityManager.getCriteriaBuilder();
CriteriaQuery<Flag> criteria = criteriaBuilder.createQuery(Flag.class);
Root<FlagShare> root = criteria.from(FlagShare.class);
criteria.select(root.get(FlagShare_.flag));
criteria.where(
criteriaBuilder.equal(root.get(FlagShare_.userIdentifier), userIdentifier)
);
return entityManager.createQuery(criteria).getResultList();
}
@Override
public void delete(FlagShare e) {
super.delete(e);
}
}