package com.commafeed.backend.dao; import java.util.List; import javax.ejb.Stateless; import javax.persistence.TypedQuery; import javax.persistence.criteria.CriteriaQuery; import javax.persistence.criteria.Root; import org.apache.commons.codec.digest.DigestUtils; import com.commafeed.backend.model.Feed; import com.commafeed.backend.model.FeedEntry; import com.commafeed.backend.model.FeedEntry_; import com.google.api.client.util.Lists; import com.uaihebert.model.EasyCriteria; @Stateless public class FeedEntryDAO extends GenericDAO { public List findByGuids(List guids) { List hashes = Lists.newArrayList(); for (String guid : guids) { hashes.add(DigestUtils.sha1Hex(guid)); } EasyCriteria criteria = createCriteria(); criteria.setDistinctTrue(); criteria.andStringIn(FeedEntry_.guidHash.getName(), hashes); criteria.leftJoinFetch(FeedEntry_.feeds.getName()); List list = Lists.newArrayList(); for (FeedEntry entry : criteria.getResultList()) { if (guids.contains(entry.getGuid())) { list.add(entry); } } return list; } public List findByFeed(Feed feed, int offset, int limit) { CriteriaQuery query = builder.createQuery(getType()); Root root = query.from(getType()); query.where(builder.isMember(feed, root.get(FeedEntry_.feeds))); query.orderBy(builder.desc(root.get(FeedEntry_.updated))); TypedQuery q = em.createQuery(query); q.setFirstResult(offset); q.setMaxResults(limit); return q.getResultList(); } }