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-05-30 12:57:14 +02:00
|
|
|
}
|
2013-06-23 15:14:14 +02:00
|
|
|
}
|
2013-05-30 12:57: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-05-30 12:57:14 +02:00
|
|
|
}
|
|
|
|
|
|
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
|
|
|
}
|