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

110 lines
3.4 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;
2013-07-01 21:15:32 +02:00
import javax.inject.Inject;
2013-04-11 20:49:08 +02:00
import javax.persistence.TypedQuery;
import javax.persistence.criteria.CriteriaQuery;
2013-07-04 21:50:39 +02:00
import javax.persistence.criteria.JoinType;
2013-04-11 20:49:08 +02:00
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_;
import com.commafeed.backend.model.FeedFeedEntry;
import com.commafeed.backend.model.FeedFeedEntry_;
2013-07-01 21:15:32 +02:00
import com.commafeed.backend.services.ApplicationSettingsService;
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-01 21:15:32 +02:00
@Inject
ApplicationSettingsService applicationSettingsService;
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 FeedFeedEntry ffe;
2013-04-14 18:28:48 +02:00
public EntryWithFeed(FeedEntry entry, FeedFeedEntry ffe) {
2013-06-23 15:14:14 +02:00
this.entry = entry;
this.ffe = ffe;
}
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.ffe != null) {
2013-06-23 16:10:34 +02:00
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());
SetJoin<FeedEntry, FeedFeedEntry> feedsJoin = root.join(FeedEntry_.feedRelationships);
2013-06-08 17:00:36 +02:00
query.where(builder.equal(feedsJoin.get(FeedFeedEntry_.feed), feed));
2013-07-20 01:10:36 +02:00
query.orderBy(builder.desc(feedsJoin.get(FeedFeedEntry_.entryUpdated)));
2013-04-11 20:49:08 +02:00
TypedQuery<FeedEntry> q = em.createQuery(query);
2013-04-25 13:14:21 +02:00
limit(q, offset, limit);
2013-07-01 21:15:32 +02:00
setTimeout(q, applicationSettingsService.get().getQueryTimeout());
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-07-04 21:50:39 +02:00
public int deleteWithoutFeeds(int max) {
CriteriaQuery<FeedEntry> query = builder.createQuery(getType());
Root<FeedEntry> root = query.from(getType());
SetJoin<FeedEntry, FeedFeedEntry> join = root.join(FeedEntry_.feedRelationships,
2013-07-04 21:50:39 +02:00
JoinType.LEFT);
query.where(builder.isNull(join.get(FeedFeedEntry_.feed)));
2013-07-04 21:50:39 +02:00
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
}