Add new API method: `getFeedStats'

`getFeedStats' calls the new static function `api_get_feed_stats' to
return an array of real feeds of the following form:

    [{
       "first" : 1127,
       "unread" : 873,
       "last" : 15460,
       "title" : "Some feed",
       "id" : 31,
       "total" : 1513
    }]

where "first", "last", "total" are the first, last and total number of
articles in the feed.

This adds the ability to nntp-oriented clients to efficiently retrieve
an "active file" without having to resort to `getHeadlines(limit=-1)'
This commit is contained in:
Pedro Silva 2013-04-11 16:25:37 +01:00
parent 063ac61353
commit 0192ffe5a5

View file

@ -110,6 +110,11 @@ class API extends Handler {
print $this->wrap(self::STATUS_OK, getAllCounters($this->link));
}
function getFeedStats() {
$feeds = $this->api_get_feed_stats($this->link);
print $this->wrap(self::STATUS_OK, $feeds);
}
function getFeeds() {
$cat_id = db_escape_string($this->link, $_REQUEST["cat_id"]);
$unread_only = sql_bool_to_bool($_REQUEST["unread_only"]);
@ -480,6 +485,38 @@ class API extends Handler {
}
}
static function api_get_feed_stats($link) {
$feeds = array();
$result = db_query($link, "SELECT ttrss_feeds.id, ttrss_feeds.title,".
" MIN(ttrss_entries.id) AS first, MAX(ttrss_entries.id) AS last,".
" COUNT(ttrss_entries.id) AS total".
" FROM ttrss_entries, ttrss_user_entries, ttrss_feeds".
" WHERE ttrss_user_entries.feed_id = ttrss_feeds.id".
" AND ttrss_user_entries.ref_id = ttrss_entries.id".
" AND ttrss_user_entries.owner_uid = ".$_SESSION["uid"].
" GROUP BY ttrss_feeds.title");
while ($line = db_fetch_assoc($result)) {
$unread = getFeedUnread($link, $line["id"]);
$row = array(
"id" => (int)$line["id"],
"title" => $line["title"],
"first" => (int)$line["first"],
"last" => (int)$line["last"],
"total" => (int)$line["total"],
"unread" => (int)$unread
);
array_push($feeds, $row);
}
return $feeds;
}
static function api_get_feeds($link, $cat_id, $unread_only, $limit, $offset, $include_nested = false) {
$feeds = array();