package org.iatoki.judgels.uriel.models.daos.impls;
import org.iatoki.judgels.play.models.daos.impls.AbstractHibernateDao;
import org.iatoki.judgels.uriel.models.daos.ContestTeamCoachDao;
import org.iatoki.judgels.uriel.models.entities.ContestTeamCoachModel;
import org.iatoki.judgels.uriel.models.entities.ContestTeamCoachModel_;
import play.db.jpa.JPA;
import javax.inject.Named;
import javax.inject.Singleton;
import javax.persistence.criteria.CriteriaBuilder;
import javax.persistence.criteria.CriteriaQuery;
import javax.persistence.criteria.Root;
import java.util.List;
@Singleton
@Named("contestTeamCoachDao")
public final class ContestTeamCoachHibernateDao extends AbstractHibernateDao<Long, ContestTeamCoachModel> implements ContestTeamCoachDao {
public ContestTeamCoachHibernateDao() {
super(ContestTeamCoachModel.class);
}
@Override
public boolean isUserRegisteredAsCoachInTeams(String userJid, List<String> teamJids) {
if (teamJids.isEmpty()) {
return false;
}
CriteriaBuilder cb = JPA.em().getCriteriaBuilder();
CriteriaQuery<Long> query = cb.createQuery(Long.class);
Root<ContestTeamCoachModel> root = query.from(getModelClass());
query.select(cb.count(root)).where(cb.and(cb.equal(root.get(ContestTeamCoachModel_.coachJid), userJid), root.get(ContestTeamCoachModel_.teamJid).in(teamJids)));
return (JPA.em().createQuery(query).getSingleResult() != 0);
}
@Override
public List<ContestTeamCoachModel> findContestTeamCoachesByTeamJid(String teamJid) {
CriteriaBuilder cb = JPA.em().getCriteriaBuilder();
CriteriaQuery<ContestTeamCoachModel> query = cb.createQuery(getModelClass());
Root<ContestTeamCoachModel> root = query.from(getModelClass());
query.where(cb.equal(root.get(ContestTeamCoachModel_.teamJid), teamJid));
return JPA.em().createQuery(query).getResultList();
}
@Override
public List<ContestTeamCoachModel> findContestTeamCoachesByCoachJidInTeams(String coachJid, List<String> teamJids) {
CriteriaBuilder cb = JPA.em().getCriteriaBuilder();
CriteriaQuery<ContestTeamCoachModel> query = cb.createQuery(getModelClass());
Root<ContestTeamCoachModel> root = query.from(getModelClass());
query.where(cb.and(cb.equal(root.get(ContestTeamCoachModel_.coachJid), coachJid), root.get(ContestTeamCoachModel_.teamJid).in(teamJids)));
return JPA.em().createQuery(query).getResultList();
}
@Override
public List<String> findContestTeamJidsByCoachJid(String coachJid) {
CriteriaBuilder cb = JPA.em().getCriteriaBuilder();
CriteriaQuery<String> query = cb.createQuery(String.class);
Root<ContestTeamCoachModel> root = query.from(getModelClass());
query.select(root.get(ContestTeamCoachModel_.teamJid)).where(cb.equal(root.get(ContestTeamCoachModel_.coachJid), coachJid));
return JPA.em().createQuery(query).getResultList();
}
@Override
public boolean isUserCoachByUserJidAndTeamJid(String userJid, String teamJid) {
CriteriaBuilder cb = JPA.em().getCriteriaBuilder();
CriteriaQuery<Long> query = cb.createQuery(Long.class);
Root<ContestTeamCoachModel> root = query.from(getModelClass());
query
.select(cb.count(root))
.where(cb.and(cb.equal(root.get(ContestTeamCoachModel_.coachJid), userJid), cb.equal(root.get(ContestTeamCoachModel_.teamJid), teamJid)));
return JPA.em().createQuery(query).getSingleResult() != 0;
}
}