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:
parent
f543f084c1
commit
e4ae3ca6ea
1 changed files with 53 additions and 38 deletions
|
@ -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) {
|
||||||
|
|
Loading…
Reference in a new issue