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

136 lines
3.8 KiB
Java
Raw Normal View History

package com.commafeed.backend.services;
import java.util.Calendar;
import java.util.Collections;
2013-07-25 11:02:49 +02:00
import java.util.Date;
import java.util.List;
import java.util.concurrent.TimeUnit;
import javax.inject.Inject;
2013-08-11 11:45:32 +02:00
import lombok.extern.slf4j.Slf4j;
2013-06-18 13:28:15 +02:00
2013-06-19 17:01:28 +02:00
import com.commafeed.backend.dao.FeedDAO;
import com.commafeed.backend.dao.FeedEntryContentDAO;
2013-06-19 13:29:56 +02:00
import com.commafeed.backend.dao.FeedEntryDAO;
2013-07-25 11:02:49 +02:00
import com.commafeed.backend.dao.FeedEntryStatusDAO;
import com.commafeed.backend.dao.FeedSubscriptionDAO;
import com.commafeed.backend.model.Feed;
import com.commafeed.backend.model.FeedEntryStatus;
import com.commafeed.backend.model.FeedSubscription;
2013-07-26 16:00:02 +02:00
/**
* Contains utility methods for cleaning the database
*
*/
2013-08-11 11:45:32 +02:00
@Slf4j
public class DatabaseCleaningService {
2013-06-19 17:01:28 +02:00
@Inject
FeedDAO feedDAO;
@Inject
2013-06-19 13:29:56 +02:00
FeedEntryDAO feedEntryDAO;
@Inject
FeedSubscriptionDAO feedSubscriptionDAO;
2013-07-25 09:17:33 +02:00
@Inject
FeedEntryContentDAO feedEntryContentDAO;
2013-07-25 11:02:49 +02:00
@Inject
FeedEntryStatusDAO feedEntryStatusDAO;
@Inject
ApplicationSettingsService applicationSettingsService;
2013-11-16 07:30:01 +01:00
public long cleanEntriesForFeedsWithoutSubscriptions() {
log.info("cleaning entries for feeds without subscriptions");
long total = 0;
int deleted = 0;
do {
deleted = 0;
List<Feed> feeds = feedDAO.findWithoutSubscriptions(1);
for (Feed feed : feeds) {
deleted += feedEntryDAO.delete(feed, 10);
total += deleted;
log.info("removed {} entries for feeds without subscriptions", total);
}
} while (deleted != 0);
log.info("cleanup done: {} entries for feeds without subscriptions deleted", total);
return total;
}
2013-06-19 17:01:28 +02:00
public long cleanFeedsWithoutSubscriptions() {
2013-11-15 21:38:11 +01:00
log.info("cleaning feeds without subscriptions");
2013-06-19 17:01:28 +02:00
long total = 0;
2013-11-16 07:30:01 +01:00
int deleted = 0;
2013-06-19 17:01:28 +02:00
do {
2013-11-16 07:30:01 +01:00
deleted = feedDAO.delete(feedDAO.findWithoutSubscriptions(10));
2013-06-19 17:01:28 +02:00
total += deleted;
log.info("removed {} feeds without subscriptions", total);
} while (deleted != 0);
log.info("cleanup done: {} feeds without subscriptions deleted", total);
return total;
}
2013-07-09 08:06:32 +02:00
public long cleanContentsWithoutEntries() {
2013-11-15 21:38:11 +01:00
log.info("cleaning contents without entries");
2013-07-04 21:50:39 +02:00
long total = 0;
2013-11-16 07:30:01 +01:00
int deleted = 0;
2013-07-04 21:50:39 +02:00
do {
deleted = feedEntryContentDAO.deleteWithoutEntries(10);
2013-07-04 21:50:39 +02:00
total += deleted;
2013-11-14 14:41:41 +01:00
log.info("removed {} contents without entries", total);
2013-07-04 21:50:39 +02:00
} while (deleted != 0);
2013-11-14 14:41:41 +01:00
log.info("cleanup done: {} contents without entries deleted", total);
2013-07-04 21:50:39 +02:00
return total;
}
2013-06-19 17:01:28 +02:00
public long cleanEntriesOlderThan(long value, TimeUnit unit) {
Calendar cal = Calendar.getInstance();
cal.add(Calendar.MINUTE, -1 * (int) unit.toMinutes(value));
2013-06-18 13:00:03 +02:00
long total = 0;
2013-11-16 07:30:01 +01:00
int deleted = 0;
2013-06-18 13:00:03 +02:00
do {
2013-06-19 13:29:56 +02:00
deleted = feedEntryDAO.delete(cal.getTime(), 100);
2013-06-18 13:00:03 +02:00
total += deleted;
2013-06-19 15:14:15 +02:00
log.info("removed {} entries", total);
2013-06-18 13:00:03 +02:00
} while (deleted != 0);
2013-06-19 15:14:15 +02:00
log.info("cleanup done: {} entries deleted", total);
2013-06-18 13:00:03 +02:00
return total;
}
public void mergeFeeds(Feed into, List<Feed> feeds) {
for (Feed feed : feeds) {
if (into.getId().equals(feed.getId())) {
continue;
}
List<FeedSubscription> subs = feedSubscriptionDAO.findByFeed(feed);
for (FeedSubscription sub : subs) {
sub.setFeed(into);
}
feedSubscriptionDAO.saveOrUpdate(subs);
feedDAO.delete(feed);
}
feedDAO.saveOrUpdate(into);
}
2013-07-25 11:02:49 +02:00
public long cleanStatusesOlderThan(Date olderThan) {
2013-07-25 11:02:49 +02:00
log.info("cleaning old read statuses");
long total = 0;
List<FeedEntryStatus> list = Collections.emptyList();
do {
list = feedEntryStatusDAO.getOldStatuses(olderThan, 100);
if (!list.isEmpty()) {
feedEntryStatusDAO.delete(list);
total += list.size();
log.info("cleaned {} old read statuses", total);
}
} while (!list.isEmpty());
log.info("cleanup done: {} old read statuses deleted", total);
return total;
2013-07-25 11:02:49 +02:00
}
}