Files
Athou_commafeed/src/main/java/com/commafeed/backend/dao/FeedEntryDAO.java

53 lines
1.6 KiB
Java
Raw Normal View History

2013-04-11 20:49:08 +02:00
package com.commafeed.backend.dao;
2013-06-19 13:29:56 +02:00
import java.util.Date;
2013-04-11 20:49:08 +02:00
import java.util.List;
import javax.ejb.Stateless;
import javax.persistence.TypedQuery;
import javax.persistence.criteria.CriteriaQuery;
import javax.persistence.criteria.Predicate;
2013-04-11 20:49:08 +02:00
import javax.persistence.criteria.Root;
2013-04-14 18:28:48 +02:00
import org.apache.commons.codec.digest.DigestUtils;
2013-04-11 20:49:08 +02:00
import com.commafeed.backend.model.FeedEntry;
import com.commafeed.backend.model.FeedEntry_;
import com.commafeed.backend.model.Feed_;
2013-06-23 15:14:14 +02:00
import com.google.common.collect.Iterables;
2013-04-11 20:49:08 +02:00
@Stateless
public class FeedEntryDAO extends GenericDAO<FeedEntry> {
2013-07-27 17:22:31 +02:00
public Long findExisting(String guid, Long feedId) {
2013-04-14 18:28:48 +02:00
2013-07-27 17:22:31 +02:00
CriteriaQuery<Long> query = builder.createQuery(Long.class);
2013-04-11 20:49:08 +02:00
Root<FeedEntry> root = query.from(getType());
2013-07-27 17:22:31 +02:00
query.select(root.get(FeedEntry_.id));
2013-06-08 17:00:36 +02:00
2013-07-25 09:17:33 +02:00
Predicate p1 = builder.equal(root.get(FeedEntry_.guidHash), DigestUtils.sha1Hex(guid));
2013-07-27 17:22:31 +02:00
Predicate p2 = builder.equal(root.get(FeedEntry_.feed).get(Feed_.id), feedId);
2013-07-27 17:22:31 +02:00
query.where(p1, p2);
2013-07-27 17:22:31 +02:00
TypedQuery<Long> q = em.createQuery(query);
limit(q, 0, 1);
List<Long> list = q.getResultList();
return Iterables.getFirst(list, null);
2013-04-11 20:49:08 +02:00
}
2013-06-19 13:29:56 +02:00
public int delete(Date olderThan, int max) {
CriteriaQuery<FeedEntry> query = builder.createQuery(getType());
Root<FeedEntry> root = query.from(getType());
query.where(builder.lessThan(root.get(FeedEntry_.inserted), olderThan));
TypedQuery<FeedEntry> q = em.createQuery(query);
q.setMaxResults(max);
List<FeedEntry> list = q.getResultList();
int deleted = list.size();
delete(list);
return deleted;
}
2013-04-11 20:49:08 +02:00
}