1
1
Fork 0
mirror of https://code.mensbeam.com/MensBeam/Arsse.git synced 2025-01-05 15:32:40 +00:00

Use constants for TTRSS' special feeds and categories

This commit is contained in:
J. King 2017-10-30 16:18:09 -04:00
parent f543f084c1
commit e4ae3ca6ea

View file

@ -35,6 +35,20 @@ class API extends \JKingWeb\Arsse\REST\AbstractHandler {
const LEVEL = 14; const LEVEL = 14;
const VERSION = "17.4"; const VERSION = "17.4";
const LABEL_OFFSET = 1024; const LABEL_OFFSET = 1024;
// special feeds
const FEED_ARCHIVED = 0;
const FEED_STARRED = -1;
const FEED_PUBLISHED = -2;
const FEED_FRESH = -3;
const FEED_ALL = -4;
const FEED_READ = -6;
// special categories
const CAT_UNCATEGORIZED = 0;
const CAT_SPECIAL = -1;
const CAT_LABELS = -2;
const CAT_NOT_SPECIAL = -3;
const CAT_ALL = -4;
// valid input
const VALID_INPUT = [ const VALID_INPUT = [
'op' => ValueInfo::T_STRING, 'op' => ValueInfo::T_STRING,
'sid' => ValueInfo::T_STRING, 'sid' => ValueInfo::T_STRING,
@ -79,6 +93,7 @@ class API extends \JKingWeb\Arsse\REST\AbstractHandler {
'data' => ValueInfo::T_STRING, 'data' => ValueInfo::T_STRING,
'pref_name' => ValueInfo::T_STRING, 'pref_name' => ValueInfo::T_STRING,
]; ];
// generic error construct
const FATAL_ERR = [ const FATAL_ERR = [
'seq' => null, 'seq' => null,
'status' => 1, 'status' => 1,
@ -228,10 +243,10 @@ class API extends \JKingWeb\Arsse\REST\AbstractHandler {
$categories[$a]['counter'] = 0; $categories[$a]['counter'] = 0;
} }
// add the "Uncategorized" and "Labels" virtual categories to the list // add the "Uncategorized" and "Labels" virtual categories to the list
$catmap[0] = sizeof($categories); $catmap[self::CAT_UNCATEGORIZED] = sizeof($categories);
$categories[] = ['id' => 0, 'name' => Arsse::$lang->msg("API.TTRSS.Category.Uncategorized"), 'parent' => 0, 'children' => 0, 'counter' => 0]; $categories[] = ['id' => self::CAT_UNCATEGORIZED, 'name' => Arsse::$lang->msg("API.TTRSS.Category.Uncategorized"), 'parent' => 0, 'children' => 0, 'counter' => 0];
$catmap[-2] = sizeof($categories); $catmap[self::CAT_LABELS] = sizeof($categories);
$categories[] = ['id' => -2, 'name' => Arsse::$lang->msg("API.TTRSS.Category.Labels"), 'parent' => 0, 'children' => 0, 'counter' => 0]; $categories[] = ['id' => self::CAT_LABELS, 'name' => Arsse::$lang->msg("API.TTRSS.Category.Labels"), 'parent' => 0, 'children' => 0, 'counter' => 0];
// prepare data for each subscription; we also add unread counts for their host categories // prepare data for each subscription; we also add unread counts for their host categories
foreach (Arsse::$db->subscriptionList($user) as $f) { foreach (Arsse::$db->subscriptionList($user) as $f) {
if ($f['unread']) { if ($f['unread']) {
@ -249,7 +264,7 @@ class API extends \JKingWeb\Arsse\REST\AbstractHandler {
foreach (Arsse::$db->labelList($user, false) as $l) { foreach (Arsse::$db->labelList($user, false) as $l) {
$unread = $l['articles'] - $l['read']; $unread = $l['articles'] - $l['read'];
$labels[] = ['id' => $this->labelOut($l['id']), 'counter' => $unread, 'auxcounter' => $l['articles']]; $labels[] = ['id' => $this->labelOut($l['id']), 'counter' => $unread, 'auxcounter' => $l['articles']];
$categories[$catmap[-2]]['counter'] += $unread; $categories[$catmap[self::CAT_LABELS]]['counter'] += $unread;
} }
// do a second pass on categories, summing descendant unread counts for ancestors, pruning categories with no unread, and building a final category list // do a second pass on categories, summing descendant unread counts for ancestors, pruning categories with no unread, and building a final category list
$cats = []; $cats = [];
@ -276,11 +291,11 @@ class API extends \JKingWeb\Arsse\REST\AbstractHandler {
$special = [ $special = [
['id' => "global-unread", 'counter' => $countAll], //this should not count archived articles, but we do not have an archive ['id' => "global-unread", 'counter' => $countAll], //this should not count archived articles, but we do not have an archive
['id' => "subscribed-feeds", 'counter' => $countSubs], ['id' => "subscribed-feeds", 'counter' => $countSubs],
['id' => 0, 'counter' => 0, 'auxcounter' => 0], // Archived articles ['id' => self::FEED_ARCHIVED, 'counter' => 0, 'auxcounter' => 0], // Archived articles
['id' => -1, 'counter' => $starred['unread'], 'auxcounter' => $starred['total']], // Starred articles ['id' => self::FEED_STARRED, 'counter' => $starred['unread'], 'auxcounter' => $starred['total']], // Starred articles
['id' => -2, 'counter' => 0, 'auxcounter' => 0], // Published articles ['id' => self::FEED_PUBLISHED, 'counter' => 0, 'auxcounter' => 0], // Published articles
['id' => -3, 'counter' => $fresh, 'auxcounter' => 0], // Fresh articles ['id' => self::FEED_FRESH, 'counter' => $fresh, 'auxcounter' => 0], // Fresh articles
['id' => -4, 'counter' => $countAll, 'auxcounter' => 0], // All articles ['id' => self::FEED_ALL, 'counter' => $countAll, 'auxcounter' => 0], // All articles
]; ];
return array_merge($special, $labels, $feeds, $cats); return array_merge($special, $labels, $feeds, $cats);
} }
@ -301,50 +316,50 @@ class API extends \JKingWeb\Arsse\REST\AbstractHandler {
// start with the special feeds // start with the special feeds
$out[] = [ $out[] = [
'name' => Arsse::$lang->msg("API.TTRSS.Category.Special"), 'name' => Arsse::$lang->msg("API.TTRSS.Category.Special"),
'id' => "CAT:-1", 'id' => "CAT:".self::CAT_SPECIAL,
'bare_id' => -1, 'bare_id' => self::CAT_SPECIAL,
'type' => "category", 'type' => "category",
'unread' => 0, 'unread' => 0,
'items' => [ 'items' => [
array_merge([ // All articles array_merge([ // All articles
'name' => Arsse::$lang->msg("API.TTRSS.Feed.All"), 'name' => Arsse::$lang->msg("API.TTRSS.Feed.All"),
'id' => "FEED:-4", 'id' => "FEED:".self::FEED_ALL,
'bare_id' => -4, 'bare_id' => self::FEED_ALL,
'icon' => "images/folder.png", 'icon' => "images/folder.png",
'unread' => array_reduce($subs, function($sum, $value) {return $sum + $value['unread'];}, 0), // the sum of all feeds' unread is the total unread 'unread' => array_reduce($subs, function($sum, $value) {return $sum + $value['unread'];}, 0), // the sum of all feeds' unread is the total unread
], $tSpecial), ], $tSpecial),
array_merge([ // Fresh articles array_merge([ // Fresh articles
'name' => Arsse::$lang->msg("API.TTRSS.Feed.Fresh"), 'name' => Arsse::$lang->msg("API.TTRSS.Feed.Fresh"),
'id' => "FEED:-3", 'id' => "FEED:".self::FEED_FRESH,
'bare_id' => -3, 'bare_id' => self::FEED_FRESH,
'icon' => "images/fresh.png", 'icon' => "images/fresh.png",
'unread' => Arsse::$db->articleCount($user, (new Context)->unread(true)->modifiedSince(Date::sub("PT24H"))), 'unread' => Arsse::$db->articleCount($user, (new Context)->unread(true)->modifiedSince(Date::sub("PT24H"))),
], $tSpecial), ], $tSpecial),
array_merge([ // Starred articles array_merge([ // Starred articles
'name' => Arsse::$lang->msg("API.TTRSS.Feed.Starred"), 'name' => Arsse::$lang->msg("API.TTRSS.Feed.Starred"),
'id' => "FEED:-1", 'id' => "FEED:".self::FEED_STARRED,
'bare_id' => -1, 'bare_id' => self::FEED_STARRED,
'icon' => "images/star.png", 'icon' => "images/star.png",
'unread' => Arsse::$db->articleStarred($user)['unread'], 'unread' => Arsse::$db->articleStarred($user)['unread'],
], $tSpecial), ], $tSpecial),
array_merge([ // Published articles array_merge([ // Published articles
'name' => Arsse::$lang->msg("API.TTRSS.Feed.Published"), 'name' => Arsse::$lang->msg("API.TTRSS.Feed.Published"),
'id' => "FEED:-2", 'id' => "FEED:".self::FEED_PUBLISHED,
'bare_id' => -2, 'bare_id' => self::FEED_PUBLISHED,
'icon' => "images/feed.png", 'icon' => "images/feed.png",
'unread' => 0, // TODO: unread count should be populated if the Published feed is ever implemented 'unread' => 0, // TODO: unread count should be populated if the Published feed is ever implemented
], $tSpecial), ], $tSpecial),
array_merge([ // Archived articles array_merge([ // Archived articles
'name' => Arsse::$lang->msg("API.TTRSS.Feed.Archived"), 'name' => Arsse::$lang->msg("API.TTRSS.Feed.Archived"),
'id' => "FEED:0", 'id' => "FEED:".self::FEED_ARCHIVED,
'bare_id' => 0, 'bare_id' => self::FEED_ARCHIVED,
'icon' => "images/archive.png", 'icon' => "images/archive.png",
'unread' => 0, // Article archiving is not exposed by the API, so this is always zero 'unread' => 0, // Article archiving is not exposed by the API, so this is always zero
], $tSpecial), ], $tSpecial),
array_merge([ // Recently read array_merge([ // Recently read
'name' => Arsse::$lang->msg("API.TTRSS.Feed.Read"), 'name' => Arsse::$lang->msg("API.TTRSS.Feed.Read"),
'id' => "FEED:-6", 'id' => "FEED:".self::FEED_READ,
'bare_id' => -6, 'bare_id' => self::FEED_READ,
'icon' => "images/time.png", 'icon' => "images/time.png",
'unread' => 0, // this is by definition zero; unread articles do not appear in this feed 'unread' => 0, // this is by definition zero; unread articles do not appear in this feed
], $tSpecial), ], $tSpecial),
@ -374,8 +389,8 @@ class API extends \JKingWeb\Arsse\REST\AbstractHandler {
if ($items) { if ($items) {
$out[] = [ $out[] = [
'name' => Arsse::$lang->msg("API.TTRSS.Category.Labels"), 'name' => Arsse::$lang->msg("API.TTRSS.Category.Labels"),
'id' => "CAT:-2", 'id' => "CAT:".self::CAT_LABELS,
'bare_id' => -2, 'bare_id' => self::CAT_LABELS,
'type' => "category", 'type' => "category",
'unread' => $unread, 'unread' => $unread,
'items' => $items, 'items' => $items,
@ -392,8 +407,8 @@ class API extends \JKingWeb\Arsse\REST\AbstractHandler {
if ($items || !$all) { if ($items || !$all) {
$out[] = [ $out[] = [
'name' => Arsse::$lang->msg("API.TTRSS.Category.Uncategorized"), 'name' => Arsse::$lang->msg("API.TTRSS.Category.Uncategorized"),
'id' => "CAT:0", 'id' => "CAT:".self::CAT_UNCATEGORIZED,
'bare_id' => 0, 'bare_id' => self::CAT_UNCATEGORIZED,
'type' => "category", 'type' => "category",
'auxcounter' => 0, 'auxcounter' => 0,
'unread' => 0, 'unread' => 0,
@ -473,12 +488,12 @@ class API extends \JKingWeb\Arsse\REST\AbstractHandler {
$cats[$a]['order'] = $a + 1; $cats[$a]['order'] = $a + 1;
} }
// add the "Uncategorized", "Special", and "Labels" virtual categories to the list // add the "Uncategorized", "Special", and "Labels" virtual categories to the list
$map[0] = sizeof($cats); $map[self::CAT_UNCATEGORIZED] = sizeof($cats);
$cats[] = ['id' => 0, 'name' => Arsse::$lang->msg("API.TTRSS.Category.Uncategorized"), 'children' => 0, 'unread' => 0, 'feeds' => 0]; $cats[] = ['id' => self::CAT_UNCATEGORIZED, 'name' => Arsse::$lang->msg("API.TTRSS.Category.Uncategorized"), 'children' => 0, 'unread' => 0, 'feeds' => 0];
$map[-1] = sizeof($cats); $map[self::CAT_SPECIAL] = sizeof($cats);
$cats[] = ['id' => -1, 'name' => Arsse::$lang->msg("API.TTRSS.Category.Special"), 'children' => 0, 'unread' => 0, 'feeds' => 6]; $cats[] = ['id' => self::CAT_SPECIAL, 'name' => Arsse::$lang->msg("API.TTRSS.Category.Special"), 'children' => 0, 'unread' => 0, 'feeds' => 6];
$map[-2] = sizeof($cats); $map[self::CAT_LABELS] = sizeof($cats);
$cats[] = ['id' => -2, 'name' => Arsse::$lang->msg("API.TTRSS.Category.Labels"), 'children' => 0, 'unread' => 0, 'feeds' => 0]; $cats[] = ['id' => self::CAT_LABELS, 'name' => Arsse::$lang->msg("API.TTRSS.Category.Labels"), 'children' => 0, 'unread' => 0, 'feeds' => 0];
// for each subscription, add the unread count to its category, and increment the category's feed count // for each subscription, add the unread count to its category, and increment the category's feed count
$subs = Arsse::$db->subscriptionList($user); $subs = Arsse::$db->subscriptionList($user);
foreach ($subs as $sub) { foreach ($subs as $sub) {
@ -491,14 +506,14 @@ class API extends \JKingWeb\Arsse\REST\AbstractHandler {
} }
// for each label, add the unread count to the labels category, and increment the labels category's feed count // for each label, add the unread count to the labels category, and increment the labels category's feed count
$labels = Arsse::$db->labelList($user); $labels = Arsse::$db->labelList($user);
$f = $map[-2]; $f = $map[self::CAT_LABELS];
foreach ($labels as $label) { foreach ($labels as $label) {
$cats[$f]['unread'] += $label['articles'] - $label['read']; $cats[$f]['unread'] += $label['articles'] - $label['read'];
$cats[$f]['feeds'] += 1; $cats[$f]['feeds'] += 1;
} }
// get the unread counts for the special feeds // get the unread counts for the special feeds
// FIXME: this is pretty inefficient // FIXME: this is pretty inefficient
$f = $map[-1]; $f = $map[self::CAT_SPECIAL];
$cats[$f]['unread'] += Arsse::$db->articleStarred($user)['unread']; // starred $cats[$f]['unread'] += Arsse::$db->articleStarred($user)['unread']; // starred
$cats[$f]['unread'] += Arsse::$db->articleCount($user, (new Context)->unread(true)->modifiedSince(Date::sub("PT24H"))); // fresh $cats[$f]['unread'] += Arsse::$db->articleCount($user, (new Context)->unread(true)->modifiedSince(Date::sub("PT24H"))); // fresh
if (!$read) { if (!$read) {