mirror of
https://github.com/Athou/commafeed.git
synced 2026-03-21 21:37:29 +00:00
display backlog in metrics
This commit is contained in:
@@ -23,10 +23,7 @@ import com.uaihebert.model.EasyCriteria;
|
||||
@Stateless
|
||||
public class FeedDAO extends GenericDAO<Feed> {
|
||||
|
||||
public List<Feed> findNextUpdatable(int count) {
|
||||
CriteriaQuery<Feed> query = builder.createQuery(getType());
|
||||
Root<Feed> root = query.from(getType());
|
||||
|
||||
private Predicate[] getUpdatablePredicates(Root<Feed> root) {
|
||||
Date now = Calendar.getInstance().getTime();
|
||||
|
||||
Predicate hasSubscriptions = builder.isNotEmpty(root
|
||||
@@ -41,14 +38,32 @@ public class FeedDAO extends GenericDAO<Feed> {
|
||||
Predicate disabledDateIsInPast = builder.lessThan(
|
||||
root.get(Feed_.disabledUntil), now);
|
||||
|
||||
query.where(hasSubscriptions,
|
||||
return new Predicate[] { hasSubscriptions,
|
||||
builder.or(neverUpdated, updatedBeforeThreshold),
|
||||
builder.or(disabledDateIsNull, disabledDateIsInPast));
|
||||
builder.or(disabledDateIsNull, disabledDateIsInPast) };
|
||||
}
|
||||
|
||||
public Long getUpdatableCount() {
|
||||
CriteriaQuery<Long> query = builder.createQuery(Long.class);
|
||||
Root<Feed> root = query.from(getType());
|
||||
|
||||
query.select(builder.count(root));
|
||||
query.where(getUpdatablePredicates(root));
|
||||
|
||||
TypedQuery<Long> q = em.createQuery(query);
|
||||
return q.getSingleResult();
|
||||
}
|
||||
|
||||
public List<Feed> findNextUpdatable(int count) {
|
||||
CriteriaQuery<Feed> query = builder.createQuery(getType());
|
||||
Root<Feed> root = query.from(getType());
|
||||
|
||||
query.where(getUpdatablePredicates(root));
|
||||
query.orderBy(builder.asc(root.get(Feed_.lastUpdated)));
|
||||
|
||||
TypedQuery<Feed> q = em.createQuery(query);
|
||||
q.setMaxResults(count);
|
||||
|
||||
|
||||
List<Feed> feeds = q.getResultList();
|
||||
for (Feed feed : feeds) {
|
||||
FeedPushInfo info = feed.getPushInfo();
|
||||
|
||||
@@ -12,7 +12,6 @@ import javax.ws.rs.core.Response.Status;
|
||||
|
||||
import org.apache.commons.lang.StringUtils;
|
||||
|
||||
import com.commafeed.backend.MetricsBean.Metric;
|
||||
import com.commafeed.backend.StartupBean;
|
||||
import com.commafeed.backend.model.ApplicationSettings;
|
||||
import com.commafeed.backend.model.User;
|
||||
@@ -177,9 +176,10 @@ public class AdminREST extends AbstractResourceREST {
|
||||
@Path("/metrics")
|
||||
@GET
|
||||
public Response getMetrics() {
|
||||
Map<String, Metric> map = ImmutableMap.of("lastMinute",
|
||||
Map<String, ? extends Object> map = ImmutableMap.of("lastMinute",
|
||||
metricsBean.getLastMinute(), "lastHour",
|
||||
metricsBean.getLastHour());
|
||||
metricsBean.getLastHour(), "backlog",
|
||||
feedDAO.getUpdatableCount());
|
||||
return Response.ok(map).build();
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user