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

86 lines
2.5 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.Root;
2013-04-25 13:14:21 +02:00
import javax.persistence.criteria.SetJoin;
2013-04-11 20:49:08 +02:00
2013-04-14 18:28:48 +02:00
import org.apache.commons.codec.digest.DigestUtils;
2013-06-23 16:10:34 +02:00
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
2013-04-14 18:28:48 +02:00
2013-04-11 20:49:08 +02:00
import com.commafeed.backend.model.Feed;
import com.commafeed.backend.model.FeedEntry;
import com.commafeed.backend.model.FeedEntry_;
2013-04-25 13:14:21 +02:00
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-06-23 16:10:34 +02:00
protected static final Logger log = LoggerFactory
.getLogger(FeedEntryDAO.class);
2013-06-23 15:14:14 +02:00
public static class EntryWithFeed {
public FeedEntry entry;
public Feed feed;
2013-04-14 18:28:48 +02:00
2013-06-23 15:14:14 +02:00
public EntryWithFeed(FeedEntry entry, Feed feed) {
this.entry = entry;
this.feed = feed;
}
2013-06-23 15:14:14 +02:00
}
2013-06-23 15:14:14 +02:00
public EntryWithFeed findExisting(String guid, String url, Long feedId) {
2013-06-08 17:00:36 +02:00
2013-06-23 15:14:14 +02:00
TypedQuery<EntryWithFeed> q = em.createNamedQuery(
"EntryStatus.existing", EntryWithFeed.class);
q.setParameter("guidHash", DigestUtils.sha1Hex(guid));
q.setParameter("url", url);
q.setParameter("feedId", feedId);
2013-06-08 17:00:36 +02:00
2013-06-23 16:10:34 +02:00
EntryWithFeed result = null;
List<EntryWithFeed> list = q.getResultList();
for (EntryWithFeed ewf : list) {
if (ewf.entry != null && ewf.feed != null) {
result = ewf;
break;
}
}
if (result == null) {
result = Iterables.getFirst(list, null);
}
return result;
}
2013-04-11 20:49:08 +02:00
public List<FeedEntry> findByFeed(Feed feed, int offset, int limit) {
CriteriaQuery<FeedEntry> query = builder.createQuery(getType());
Root<FeedEntry> root = query.from(getType());
2013-04-25 13:14:21 +02:00
SetJoin<FeedEntry, Feed> feedsJoin = root.join(FeedEntry_.feeds);
2013-06-08 17:00:36 +02:00
2013-04-25 13:14:21 +02:00
query.where(builder.equal(feedsJoin.get(Feed_.id), feed.getId()));
2013-04-11 20:49:08 +02:00
query.orderBy(builder.desc(root.get(FeedEntry_.updated)));
TypedQuery<FeedEntry> q = em.createQuery(query);
2013-04-25 13:14:21 +02:00
limit(q, offset, limit);
2013-04-11 20:49:08 +02:00
return q.getResultList();
}
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
}