Files
Athou_commafeed/src/main/java/com/commafeed/backend/services/FeedSubscriptionService.java

123 lines
3.5 KiB
Java
Raw Normal View History

2013-04-11 20:49:08 +02:00
package com.commafeed.backend.services;
import java.util.List;
2013-07-03 12:42:01 +02:00
import java.util.Map;
2013-04-11 20:49:08 +02:00
import javax.ejb.ApplicationException;
2013-04-11 20:49:08 +02:00
import javax.inject.Inject;
import org.apache.commons.lang.StringUtils;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
2013-07-03 12:42:01 +02:00
import com.commafeed.backend.cache.CacheService;
2013-04-11 20:49:08 +02:00
import com.commafeed.backend.dao.FeedEntryDAO;
import com.commafeed.backend.dao.FeedEntryStatusDAO;
import com.commafeed.backend.dao.FeedSubscriptionDAO;
import com.commafeed.backend.feeds.FeedRefreshTaskGiver;
import com.commafeed.backend.feeds.FeedUtils;
2013-04-11 20:49:08 +02:00
import com.commafeed.backend.model.Feed;
import com.commafeed.backend.model.FeedCategory;
import com.commafeed.backend.model.FeedEntry;
import com.commafeed.backend.model.FeedEntryStatus;
import com.commafeed.backend.model.FeedSubscription;
2013-07-03 12:42:01 +02:00
import com.commafeed.backend.model.Models;
2013-04-11 20:49:08 +02:00
import com.commafeed.backend.model.User;
import com.google.api.client.util.Lists;
public class FeedSubscriptionService {
2013-05-20 21:53:13 +02:00
2013-07-03 12:42:01 +02:00
private static Logger log = LoggerFactory
.getLogger(FeedSubscriptionService.class);
2013-05-20 21:53:13 +02:00
@SuppressWarnings("serial")
@ApplicationException
2013-05-20 21:53:13 +02:00
public static class FeedSubscriptionException extends RuntimeException {
public FeedSubscriptionException(String msg) {
super(msg);
}
}
2013-04-11 20:49:08 +02:00
@Inject
2013-04-21 11:24:45 +02:00
FeedService feedService;
2013-04-11 20:49:08 +02:00
@Inject
FeedEntryDAO feedEntryDAO;
@Inject
FeedEntryStatusDAO feedEntryStatusDAO;
@Inject
FeedSubscriptionDAO feedSubscriptionDAO;
2013-04-30 22:05:38 +02:00
@Inject
ApplicationSettingsService applicationSettingsService;
@Inject
FeedRefreshTaskGiver taskGiver;
2013-04-11 20:49:08 +02:00
2013-07-03 12:42:01 +02:00
@Inject
CacheService cache;
public Feed subscribe(User user, String url, String title,
2013-04-11 20:49:08 +02:00
FeedCategory category) {
final String pubUrl = applicationSettingsService.get().getPublicUrl();
if (StringUtils.isBlank(pubUrl)) {
throw new FeedSubscriptionException(
2013-05-22 21:56:22 +02:00
"Public URL of this CommaFeed instance is not set");
}
if (url.startsWith(pubUrl)) {
2013-05-20 21:53:13 +02:00
throw new FeedSubscriptionException(
2013-04-30 22:05:38 +02:00
"Could not subscribe to a feed from this CommaFeed instance");
}
2013-04-21 11:24:45 +02:00
Feed feed = feedService.findOrCreate(url);
2013-04-11 20:49:08 +02:00
FeedSubscription sub = feedSubscriptionDAO.findByFeed(user, feed);
boolean newSubscription = false;
if (sub == null) {
sub = new FeedSubscription();
sub.setFeed(feed);
sub.setUser(user);
newSubscription = true;
}
sub.setCategory(category);
2013-06-04 10:11:16 +02:00
sub.setPosition(0);
sub.setTitle(FeedUtils.truncate(title, 128));
2013-04-11 20:49:08 +02:00
feedSubscriptionDAO.saveOrUpdate(sub);
if (newSubscription) {
try {
List<FeedEntryStatus> statuses = Lists.newArrayList();
2013-07-03 12:42:01 +02:00
List<FeedEntry> allEntries = feedEntryDAO.findByFeed(feed, 0,
10);
for (FeedEntry entry : allEntries) {
FeedEntryStatus status = new FeedEntryStatus(user, sub, entry);
status.setRead(false);
status.setSubscription(sub);
statuses.add(status);
}
feedEntryStatusDAO.saveOrUpdate(statuses);
} catch (Exception e) {
2013-07-03 12:42:01 +02:00
log.error(
"could not fetch initial statuses when importing {} : {}",
feed.getUrl(), e.getMessage());
2013-04-11 20:49:08 +02:00
}
}
taskGiver.add(feed);
return feed;
2013-04-11 20:49:08 +02:00
}
2013-07-03 12:42:01 +02:00
public Map<Long, Long> getUnreadCount(User user) {
Map<Long, Long> map = cache.getUnreadCounts(user);
if (map == null) {
log.debug("unread count cache miss for {}", Models.getId(user));
List<FeedSubscription> subs = feedSubscriptionDAO.findAll(user);
map = feedEntryStatusDAO.getUnreadCount(subs);
2013-07-03 12:42:01 +02:00
cache.setUnreadCounts(user, map);
}
return map;
}
2013-04-11 20:49:08 +02:00
}