2013-02-21 14:58:06 +00:00
< ? php
require_once " colors.php " ;
class Feeds extends Handler_Protected {
2015-06-07 15:41:18 +00:00
private $params ;
function csrf_ignore ( $method ) {
2013-04-01 07:14:27 +00:00
$csrf_ignored = array ( " index " , " feedbrowser " , " quickaddfeed " , " search " );
2013-02-21 14:58:06 +00:00
return array_search ( $method , $csrf_ignored ) !== false ;
}
private function format_headline_subtoolbar ( $feed_site_url , $feed_title ,
2013-03-20 23:36:30 +00:00
$feed_id , $is_cat , $search ,
2017-04-26 12:29:22 +00:00
$error , $feed_last_updated ) {
2013-02-21 14:58:06 +00:00
if ( $is_cat ) $cat_q = " &is_cat= $is_cat " ;
if ( $search ) {
2015-07-07 12:59:32 +00:00
$search_q = " &q= $search " ;
2013-02-21 14:58:06 +00:00
} else {
$search_q = " " ;
}
2018-12-04 19:24:31 +00:00
$reply = " " ;
2014-01-27 18:03:42 +00:00
2013-02-21 14:58:06 +00:00
$rss_link = htmlspecialchars ( get_self_url_prefix () .
" /public.php?op=rss&id= $feed_id $cat_q $search_q " );
2013-07-12 08:38:50 +00:00
$error_class = $error ? " error " : " " ;
2018-12-04 19:24:31 +00:00
$reply .= " <span class='left'> " ;
$reply .= " <a href= \" # \"
2018-12-02 05:57:22 +00:00
title = \ " " . __ ( " Show as feed " ) . " \"
2018-12-02 19:08:18 +00:00
onclick = \ " App.displayDlg(' " . __ ( " Show as feed " ) . " ','generatedFeed', ' $feed_id : $is_cat : $rss_link ') \" >
2018-12-05 11:11:40 +00:00
< i class = 'icon-syndicate material-icons' > rss_feed </ i ></ a > " ;
2014-01-27 18:03:42 +00:00
2013-07-12 08:38:50 +00:00
$reply .= " <span id='feed_title' class=' $error_class '> " ;
2013-02-21 14:58:06 +00:00
if ( $feed_site_url ) {
2013-04-25 12:27:33 +00:00
$last_updated = T_sprintf ( " Last updated: %s " ,
$feed_last_updated );
2013-02-21 14:58:06 +00:00
$target = " target= \" _blank \" " ;
2013-04-25 12:27:33 +00:00
$reply .= " <a title= \" $last_updated\ " $target href = \ " $feed_site_url\ " > " .
2017-12-03 20:08:04 +00:00
truncate_string ( strip_tags ( $feed_title ), 30 ) . " </a> " ;
2013-02-21 14:58:06 +00:00
if ( $error ) {
2013-07-13 18:14:18 +00:00
$error = htmlspecialchars ( $error );
2014-03-26 10:30:54 +00:00
$reply .= " <img title= \" $error\ " src = 'images/error.png' alt = 'error' class = \ " noborder \" > " ;
2013-02-21 14:58:06 +00:00
}
} else {
2017-12-03 20:08:04 +00:00
$reply .= strip_tags ( $feed_title );
2013-02-21 14:58:06 +00:00
}
2018-12-04 19:24:31 +00:00
$reply .= " </span></span> " ;
2013-02-21 14:58:06 +00:00
2018-12-04 19:24:31 +00:00
$reply .= " <span class= \" right \" > " ;
2014-01-27 18:27:31 +00:00
$reply .= " <span id='selected_prompt'></span> " ;
2018-12-04 19:24:31 +00:00
$reply .= " " ;
2013-02-21 14:58:06 +00:00
$reply .= " <select dojoType= \" dijit.form.Select \"
2018-12-01 18:51:00 +00:00
onchange = \ " Headlines.onActionChanged(this) \" > " ;
2017-01-07 14:03:58 +00:00
$reply .= " <option value= \" 0 \" disabled='1'> " . __ ( 'Select...' ) . " </option> " ;
2018-12-04 19:24:31 +00:00
$reply .= " <option value= \" Headlines.select('all') \" > " . __ ( 'All' ) . " </option> " ;
$reply .= " <option value= \" Headlines.select('unread') \" > " . __ ( 'Unread' ) . " </option> " ;
$reply .= " <option value= \" Headlines.select('invert') \" > " . __ ( 'Invert' ) . " </option> " ;
$reply .= " <option value= \" Headlines.select('none') \" > " . __ ( 'None' ) . " </option> " ;
2013-02-21 14:58:06 +00:00
$reply .= " <option value= \" 0 \" disabled= \" 1 \" > " . __ ( 'Selection toggle:' ) . " </option> " ;
2018-12-04 19:24:31 +00:00
$reply .= " <option value= \" Headlines.selectionToggleUnread() \" > " . __ ( 'Unread' ) . " </option>
< option value = \ " Headlines.selectionToggleMarked() \" > " . __ ( 'Starred' ) . " </option>
< option value = \ " Headlines.selectionTogglePublished() \" > " . __ ( 'Published' ) . " </option> " ;
2013-02-21 14:58:06 +00:00
$reply .= " <option value= \" 0 \" disabled= \" 1 \" > " . __ ( 'Selection:' ) . " </option> " ;
2018-12-04 19:24:31 +00:00
$reply .= " <option value= \" Headlines.catchupSelection() \" > " . __ ( 'Mark as read' ) . " </option> " ;
$reply .= " <option value= \" Article.selectionSetScore() \" > " . __ ( 'Set score' ) . " </option> " ;
2013-02-21 14:58:06 +00:00
2018-12-04 19:24:31 +00:00
if ( $feed_id == 0 && ! $is_cat ) {
$reply .= " <option value= \" Headlines.archiveSelection() \" > " . __ ( 'Move back' ) . " </option> " ;
$reply .= " <option value= \" Headlines.deleteSelection() \" > " . __ ( 'Delete' ) . " </option> " ;
2013-02-21 14:58:06 +00:00
} else {
2018-12-04 19:24:31 +00:00
$reply .= " <option value= \" Headlines.archiveSelection() \" > " . __ ( 'Archive' ) . " </option> " ;
2013-02-21 14:58:06 +00:00
}
2013-04-18 08:27:34 +00:00
if ( PluginHost :: getInstance () -> get_plugin ( " mail " )) {
2018-12-03 11:21:50 +00:00
$reply .= " <option value= \" Plugins.Mail.send() \" > " . __ ( 'Forward by email' ) .
2013-02-21 14:58:06 +00:00
" </option> " ;
}
2013-04-18 08:27:34 +00:00
if ( PluginHost :: getInstance () -> get_plugin ( " mailto " )) {
2018-12-03 11:21:50 +00:00
$reply .= " <option value= \" Plugins.Mailto.send() \" > " . __ ( 'Forward by email' ) .
2013-03-19 14:32:49 +00:00
" </option> " ;
}
2013-02-21 14:58:06 +00:00
$reply .= " <option value= \" 0 \" disabled= \" 1 \" > " . __ ( 'Feed:' ) . " </option> " ;
2013-03-31 11:39:10 +00:00
//$reply .= "<option value=\"catchupPage()\">".__('Mark as read')."</option>";
2013-02-21 14:58:06 +00:00
2018-12-02 19:08:18 +00:00
$reply .= " <option value= \" App.displayDlg(' " . __ ( " Show as feed " ) . " ','generatedFeed', ' $feed_id : $is_cat : $rss_link ') \" > " .
2018-12-02 05:57:22 +00:00
__ ( 'Show as feed' ) . " </option> " ;
2013-02-21 14:58:06 +00:00
$reply .= " </select> " ;
//$reply .= "</h2";
2013-04-18 08:27:34 +00:00
foreach ( PluginHost :: getInstance () -> get_hooks ( PluginHost :: HOOK_HEADLINE_TOOLBAR_BUTTON ) as $p ) {
2014-08-18 11:22:02 +00:00
$reply .= $p -> hook_headline_toolbar_button ( $feed_id , $is_cat );
2013-04-01 14:06:09 +00:00
}
2018-12-04 19:24:31 +00:00
$reply .= " </span> " ;
2014-01-27 18:03:42 +00:00
2013-02-21 14:58:06 +00:00
return $reply ;
}
private function format_headlines_list ( $feed , $method , $view_mode , $limit , $cat_view ,
2017-04-26 12:29:22 +00:00
$offset , $vgr_last_feed = false ,
2015-11-21 19:20:00 +00:00
$override_order = false , $include_children = false , $check_first_id = false ,
$skip_first_id_check = false ) {
2013-02-21 14:58:06 +00:00
$disable_cache = false ;
$reply = array ();
2013-04-15 11:27:35 +00:00
$rgba_cache = array ();
2013-02-27 18:16:58 +00:00
$timing_info = microtime ( true );
2013-02-21 14:58:06 +00:00
$topmost_article_ids = array ();
if ( ! $offset ) $offset = 0 ;
if ( $method == " undefined " ) $method = " " ;
$method_split = explode ( " : " , $method );
2016-01-26 08:45:47 +00:00
if ( $method == " ForceUpdate " && $feed > 0 && is_numeric ( $feed )) {
2018-11-03 12:08:43 +00:00
$sth = $this -> pdo -> prepare ( " UPDATE ttrss_feeds
2017-12-31 04:37:49 +00:00
SET last_updated = '1970-01-01' , last_update_started = '1970-01-01'
WHERE id = ? " );
$sth -> execute ([ $feed ]);
2013-02-21 14:58:06 +00:00
}
if ( $method_split [ 0 ] == " MarkAllReadGR " ) {
move the following to Feeds:
+ static function catchup_feed($feed, $cat_view, $owner_uid = false, $mode = 'all', $search = false) {
+ static function getFeedArticles($feed, $is_cat = false, $unread_only = false,
+ static function subscribe_to_feed($url, $cat_id = 0,
+ static function getFeedIcon($id) {
+ static function getFeedTitle($id, $cat = false) {
+ static function getCategoryUnread($cat, $owner_uid = false) {
+ static function getCategoryChildrenUnread($cat, $owner_uid = false) {
2017-05-04 11:50:56 +00:00
$this -> catchup_feed ( $method_split [ 1 ], false );
2013-02-21 14:58:06 +00:00
}
// FIXME: might break tag display?
if ( is_numeric ( $feed ) && $feed > 0 && ! $cat_view ) {
2017-12-01 17:15:25 +00:00
$sth = $this -> pdo -> prepare ( " SELECT id FROM ttrss_feeds WHERE id = ? LIMIT 1 " );
$sth -> execute ([ $feed ]);
2013-02-21 14:58:06 +00:00
2017-12-01 17:15:25 +00:00
if ( ! $sth -> fetch ()) {
2013-02-21 14:58:06 +00:00
$reply [ 'content' ] = " <div align='center'> " . __ ( 'Feed not found.' ) . " </div> " ;
}
}
2017-12-01 17:26:51 +00:00
@ $search = $_REQUEST [ " query " ];
@ $search_language = $_REQUEST [ " search_language " ]; // PGSQL only
2013-02-21 14:58:06 +00:00
if ( $search ) {
$disable_cache = true ;
}
if ( $_REQUEST [ " debug " ]) $timing_info = print_checkpoint ( " H0 " , $timing_info );
2013-03-28 19:34:35 +00:00
if ( ! $cat_view && is_numeric ( $feed ) && $feed < PLUGIN_FEED_BASE_INDEX && $feed > LABEL_BASE_INDEX ) {
2013-04-18 08:27:34 +00:00
$handler = PluginHost :: getInstance () -> get_feed_handler (
2013-03-27 12:14:27 +00:00
PluginHost :: feed_to_pfeed_id ( $feed ));
if ( $handler ) {
$options = array (
" limit " => $limit ,
" view_mode " => $view_mode ,
" cat_view " => $cat_view ,
" search " => $search ,
" override_order " => $override_order ,
" offset " => $offset ,
" owner_uid " => $_SESSION [ " uid " ],
" filter " => false ,
" since_id " => 0 ,
" include_children " => $include_children );
$qfh_ret = $handler -> get_headlines ( PluginHost :: feed_to_pfeed_id ( $feed ),
$options );
}
} else {
2015-07-11 22:29:36 +00:00
$params = array (
" feed " => $feed ,
" limit " => $limit ,
" view_mode " => $view_mode ,
" cat_view " => $cat_view ,
" search " => $search ,
2015-08-04 10:53:48 +00:00
" search_language " => $search_language ,
2015-07-11 22:29:36 +00:00
" override_order " => $override_order ,
" offset " => $offset ,
" include_children " => $include_children ,
2015-11-21 19:20:00 +00:00
" check_first_id " => $check_first_id ,
" skip_first_id_check " => $skip_first_id_check
2015-07-11 22:29:36 +00:00
);
2017-05-04 12:13:02 +00:00
$qfh_ret = $this -> queryFeedHeadlines ( $params );
2013-03-27 12:14:27 +00:00
}
2013-02-21 14:58:06 +00:00
2014-03-12 21:07:52 +00:00
$vfeed_group_enabled = get_pref ( " VFEED_GROUP_BY_FEED " ) && $feed != - 6 ;
2013-02-21 14:58:06 +00:00
if ( $_REQUEST [ " debug " ]) $timing_info = print_checkpoint ( " H1 " , $timing_info );
2017-12-04 07:26:22 +00:00
$result = $qfh_ret [ 0 ]; // this could be either a PDO query result or a -1 if first id changed
2013-02-21 14:58:06 +00:00
$feed_title = $qfh_ret [ 1 ];
$feed_site_url = $qfh_ret [ 2 ];
$last_error = $qfh_ret [ 3 ];
2013-04-25 14:42:48 +00:00
$last_updated = strpos ( $qfh_ret [ 4 ], '1970-' ) === FALSE ?
make_local_datetime ( $qfh_ret [ 4 ], false ) : __ ( " Never " );
2013-07-31 10:53:34 +00:00
$highlight_words = $qfh_ret [ 5 ];
2015-07-12 14:55:35 +00:00
$reply [ 'first_id' ] = $qfh_ret [ 6 ];
2017-03-31 08:21:35 +00:00
$reply [ 'search_query' ] = [ $search , $search_language ];
2013-02-21 14:58:06 +00:00
$vgroup_last_feed = $vgr_last_feed ;
$reply [ 'toolbar' ] = $this -> format_headline_subtoolbar ( $feed_site_url ,
$feed_title ,
2017-04-26 12:29:22 +00:00
$feed , $cat_view , $search ,
2013-04-25 12:27:33 +00:00
$last_error , $last_updated );
2013-02-21 14:58:06 +00:00
2014-08-19 10:24:34 +00:00
if ( $offset == 0 ) {
foreach ( PluginHost :: getInstance () -> get_hooks ( PluginHost :: HOOK_HEADLINES_BEFORE ) as $p ) {
$reply [ 'content' ] .= $p -> hook_headlines_before ( $feed , $cat_view , $qfh_ret );
}
}
2015-07-13 19:01:29 +00:00
$reply [ 'content' ] = '' ;
2015-07-13 10:29:13 +00:00
2017-12-01 17:25:13 +00:00
$headlines_count = 0 ;
$lnum = $offset ;
$num_unread = 0 ;
if ( $_REQUEST [ " debug " ]) $timing_info = print_checkpoint ( " PS " , $timing_info );
2017-12-04 07:26:22 +00:00
if ( is_object ( $result )) {
2017-12-01 17:25:13 +00:00
2017-12-04 07:26:22 +00:00
while ( $line = $result -> fetch ()) {
2017-12-01 17:25:13 +00:00
2017-12-04 07:26:22 +00:00
++ $headlines_count ;
2013-02-21 14:58:06 +00:00
2017-12-04 07:26:22 +00:00
$line [ " content_preview " ] = " — " . truncate_string ( strip_tags ( $line [ " content " ]), 250 );
2013-02-21 14:58:06 +00:00
2017-12-04 07:26:22 +00:00
foreach ( PluginHost :: getInstance () -> get_hooks ( PluginHost :: HOOK_QUERY_HEADLINES ) as $p ) {
$line = $p -> hook_query_headlines ( $line , 250 , false );
}
2013-02-21 14:58:06 +00:00
2017-12-04 07:26:22 +00:00
if ( get_pref ( 'SHOW_CONTENT_PREVIEW' )) {
$content_preview = $line [ " content_preview " ];
}
2013-02-21 14:58:06 +00:00
2017-12-04 07:26:22 +00:00
$id = $line [ " id " ];
$feed_id = $line [ " feed_id " ];
$label_cache = $line [ " label_cache " ];
$labels = false ;
2013-07-10 12:52:03 +00:00
2018-12-01 18:51:00 +00:00
$mouseover_attrs = " onmouseover='Article.mouseIn( $id )' onmouseout='Article.mouseOut( $id )' " ;
2017-12-04 07:39:50 +00:00
2017-12-04 07:26:22 +00:00
if ( $label_cache ) {
$label_cache = json_decode ( $label_cache , true );
2015-07-12 22:19:52 +00:00
2017-12-04 07:26:22 +00:00
if ( $label_cache ) {
if ( $label_cache [ " no-labels " ] == 1 )
$labels = array ();
else
$labels = $label_cache ;
}
}
2013-07-10 12:52:03 +00:00
2017-12-04 07:26:22 +00:00
if ( ! is_array ( $labels )) $labels = Article :: get_article_labels ( $id );
2013-07-10 12:52:03 +00:00
2017-12-04 07:26:22 +00:00
$labels_str = " <span class= \" HLLCTR- $id\ " > " ;
$labels_str .= Article :: format_article_labels ( $labels );
$labels_str .= " </span> " ;
2013-07-10 12:52:03 +00:00
2017-12-04 07:26:22 +00:00
if ( count ( $topmost_article_ids ) < 3 ) {
array_push ( $topmost_article_ids , $id );
}
2013-02-21 14:58:06 +00:00
2017-12-04 07:26:22 +00:00
$class = " " ;
2013-02-21 14:58:06 +00:00
2017-12-04 07:26:22 +00:00
if ( $line [ " unread " ]) {
$class .= " Unread " ;
++ $num_unread ;
}
2017-12-04 07:39:50 +00:00
$class .= $line [ " marked " ] ? " marked " : " " ;
2018-12-05 07:50:50 +00:00
$marked_pic = " <i class= \" marked-pic marked- $id material-icons \" onclick='Headlines.toggleMark( $id )'>star</i> " ;
2013-02-21 14:58:06 +00:00
2017-12-04 07:39:50 +00:00
$class .= $line [ " published " ] ? " published " : " " ;
2018-12-05 07:50:50 +00:00
$published_pic = " <i class= \" pub-pic pub- $id material-icons \" onclick='Headlines.togglePub( $id )'>rss_feed</i> " ;
2013-02-21 14:58:06 +00:00
2017-12-04 07:26:22 +00:00
$updated_fmt = make_local_datetime ( $line [ " updated " ], false , false , false , true );
$date_entered_fmt = T_sprintf ( " Imported at %s " ,
make_local_datetime ( $line [ " date_entered " ], false ));
2013-02-21 14:58:06 +00:00
2017-12-04 07:26:22 +00:00
$score = $line [ " score " ];
2013-02-21 14:58:06 +00:00
2017-12-04 07:26:22 +00:00
$score_pic = " images/ " . get_score_pic ( $score );
2013-05-04 08:01:53 +00:00
2018-12-02 05:32:13 +00:00
$score_pic = " <img class='score-pic' score=' $score ' onclick='Article.setScore( $id , this)' src= \" $score_pic\ "
2017-12-01 17:25:13 +00:00
title = \ " $score\ " > " ;
2013-02-21 14:58:06 +00:00
2017-12-04 07:26:22 +00:00
if ( $score > 500 ) {
$hlc_suffix = " high " ;
} else if ( $score < - 100 ) {
$hlc_suffix = " low " ;
} else {
$hlc_suffix = " " ;
}
2013-02-21 14:58:06 +00:00
2017-12-04 07:26:22 +00:00
$entry_author = $line [ " author " ];
2013-02-21 14:58:06 +00:00
2017-12-04 07:26:22 +00:00
if ( $entry_author ) {
$entry_author = " — $entry_author " ;
}
2013-02-21 14:58:06 +00:00
2018-11-30 11:53:58 +00:00
if ( feeds :: feedHasIcon ( $feed_id )) {
2017-12-04 07:26:22 +00:00
$feed_icon_img = " <img class= \" tinyFeedIcon \" src= \" " . ICONS_URL . " / $feed_id .ico \" alt= \" \" > " ;
} else {
2018-12-05 11:18:03 +00:00
$feed_icon_img = " <i class='icon-syndicate material-icons'>rss_feed</i> " ;
2017-12-04 07:26:22 +00:00
}
2013-02-21 14:58:06 +00:00
2017-12-04 07:26:22 +00:00
$entry_site_url = $line [ " site_url " ];
2013-02-21 14:58:06 +00:00
2017-12-04 07:26:22 +00:00
//setting feed headline background color, needs to change text color based on dark/light
$fav_color = $line [ 'favicon_avg_color' ];
2013-02-21 14:58:06 +00:00
2017-12-04 07:26:22 +00:00
require_once " colors.php " ;
2013-02-21 14:58:06 +00:00
2017-12-04 07:26:22 +00:00
if ( $fav_color && $fav_color != 'fail' ) {
if ( ! isset ( $rgba_cache [ $feed_id ])) {
$rgba_cache [ $feed_id ] = join ( " , " , _color_unpack ( $fav_color ));
}
}
2013-02-21 14:58:06 +00:00
2017-12-04 07:26:22 +00:00
if ( ! get_pref ( 'COMBINED_DISPLAY_MODE' )) {
2013-02-21 14:58:06 +00:00
2017-12-04 07:26:22 +00:00
if ( $vfeed_group_enabled ) {
if ( $feed_id != $vgroup_last_feed && $line [ " feed_title " ]) {
2013-02-21 14:58:06 +00:00
2017-12-04 07:26:22 +00:00
$vgroup_last_feed = $feed_id ;
2013-02-21 14:58:06 +00:00
2018-12-01 14:21:26 +00:00
$vf_catchup_link = " <a class='catchup' onclick='Feeds.catchupFeedInGroup( $feed_id );' href='#'> " . __ ( 'mark feed as read' ) . " </a> " ;
2013-02-21 14:58:06 +00:00
2018-12-01 18:08:15 +00:00
$reply [ 'content' ] .= " <div data-feed-id=' $feed_id ' class='feed-title'> " .
2017-12-04 07:26:22 +00:00
" <div style='float : right'> $feed_icon_img </div> " .
2018-12-02 05:57:22 +00:00
" <a class='title' href= \" # \" onclick= \" Feeds.open( { feed: $feed_id }) \" > " .
2017-12-04 07:26:22 +00:00
$line [ " feed_title " ] . " </a>
2017-12-01 17:25:13 +00:00
$vf_catchup_link </ div > " ;
2013-02-21 14:58:06 +00:00
2013-03-18 11:42:28 +00:00
2017-12-04 07:26:22 +00:00
}
}
2013-04-15 11:38:05 +00:00
2018-12-05 04:34:16 +00:00
$reply [ 'content' ] .= " <div class='hl $class ' data-orig-feed-id=' $feed_id ' data-article-id=' $id ' id='RROW- $id ' $mouseover_attrs > " ;
2013-04-15 11:38:05 +00:00
2018-11-30 14:42:38 +00:00
$reply [ 'content' ] .= " <div class='left'> " ;
2013-02-21 14:58:06 +00:00
2017-12-04 07:26:22 +00:00
$reply [ 'content' ] .= " <input dojoType= \" dijit.form.CheckBox \"
2018-12-02 07:33:58 +00:00
type = \ " checkbox \" onclick= \" Headlines.onRowChecked(this) \"
2017-12-01 17:25:13 +00:00
class = 'rchk' > " ;
2013-02-21 14:58:06 +00:00
2017-12-04 07:26:22 +00:00
$reply [ 'content' ] .= " $marked_pic " ;
$reply [ 'content' ] .= " $published_pic " ;
2013-02-21 14:58:06 +00:00
2017-12-04 07:26:22 +00:00
$reply [ 'content' ] .= " </div> " ;
2013-02-21 14:58:06 +00:00
2018-12-01 14:54:16 +00:00
$reply [ 'content' ] .= " <div onclick='return Headlines.click(event, $id )'
2018-12-05 04:34:16 +00:00
class = \ " title \" ><span data-article-id= \" $id\ " class = 'hl-content hlMenuAttach $hlc_suffix' > " ;
2018-11-30 11:39:06 +00:00
$reply [ 'content' ] .= " <a class= \" title $hlc_suffix\ "
2017-12-01 17:25:13 +00:00
href = \ " " . htmlspecialchars ( $line [ " link " ]) . " \"
onclick = \ " \" > " .
2017-12-04 07:26:22 +00:00
truncate_string ( $line [ " title " ], 200 );
2013-02-21 14:58:06 +00:00
2017-12-04 07:26:22 +00:00
if ( get_pref ( 'SHOW_CONTENT_PREVIEW' )) {
2018-11-30 14:42:38 +00:00
$reply [ 'content' ] .= " <span class= \" preview \" > " . $line [ " content_preview " ] . " </span> " ;
2017-12-04 07:26:22 +00:00
}
2013-02-21 14:58:06 +00:00
2017-12-04 07:26:22 +00:00
$reply [ 'content' ] .= " </a></span> " ;
2015-07-12 22:19:52 +00:00
2017-12-04 07:26:22 +00:00
$reply [ 'content' ] .= $labels_str ;
2013-02-21 14:58:06 +00:00
2017-12-04 07:26:22 +00:00
$reply [ 'content' ] .= " </div> " ;
2013-02-21 14:58:06 +00:00
2017-12-04 07:26:22 +00:00
if ( ! $vfeed_group_enabled ) {
if ( @ $line [ " feed_title " ]) {
$rgba = @ $rgba_cache [ $feed_id ];
2013-02-21 14:58:06 +00:00
2018-12-02 05:57:22 +00:00
$reply [ 'content' ] .= " <span class= \" feed \" ><a style= \" background : rgba( $rgba , 0.3) \" href= \" # \" onclick= \" Feeds.open( { feed: $feed_id }) \" > " .
2017-12-04 07:26:22 +00:00
truncate_string ( $line [ " feed_title " ], 30 ) . " </a></span> " ;
}
}
2013-02-21 14:58:06 +00:00
2018-11-30 14:42:38 +00:00
$reply [ 'content' ] .= " <span class= \" updated \" > " ;
2013-02-21 14:58:06 +00:00
2017-12-04 07:26:22 +00:00
$reply [ 'content' ] .= " <div title=' $date_entered_fmt '> $updated_fmt </div>
2017-12-01 17:25:13 +00:00
</ span > " ;
2013-02-21 14:58:06 +00:00
2018-11-30 14:42:38 +00:00
$reply [ 'content' ] .= " <div class= \" right \" > " ;
2013-02-21 14:58:06 +00:00
2017-12-04 07:26:22 +00:00
$reply [ 'content' ] .= $score_pic ;
2013-02-21 14:58:06 +00:00
2017-12-04 07:26:22 +00:00
if ( $line [ " feed_title " ] && ! $vfeed_group_enabled ) {
2013-02-21 14:58:06 +00:00
2018-12-02 05:57:22 +00:00
$reply [ 'content' ] .= " <span onclick= \" Feeds.open( { feed: $feed_id }) \"
2017-12-01 17:25:13 +00:00
style = \ " cursor : pointer \"
title = \ " " . htmlspecialchars ( $line [ 'feed_title' ]) . " \" >
$feed_icon_img </ span > " ;
2017-12-04 07:26:22 +00:00
}
2013-02-21 14:58:06 +00:00
2017-12-04 07:26:22 +00:00
$reply [ 'content' ] .= " </div> " ;
$reply [ 'content' ] .= " </div> " ;
2013-03-16 13:17:55 +00:00
2017-12-04 07:26:22 +00:00
} else {
2013-05-07 15:39:04 +00:00
2017-12-04 07:26:22 +00:00
if ( $line [ " tag_cache " ])
$tags = explode ( " , " , $line [ " tag_cache " ]);
else
$tags = false ;
2013-02-21 14:58:06 +00:00
2017-12-04 07:26:22 +00:00
$line [ " content " ] = sanitize ( $line [ " content " ],
$line [ 'hide_images' ], false , $entry_site_url , $highlight_words , $line [ " id " ]);
2014-01-28 20:21:57 +00:00
2017-12-04 07:26:22 +00:00
foreach ( PluginHost :: getInstance () -> get_hooks ( PluginHost :: HOOK_RENDER_ARTICLE_CDM ) as $p ) {
$line = $p -> hook_render_article_cdm ( $line );
}
2014-01-28 20:21:57 +00:00
2018-08-20 09:12:32 +00:00
$line [ 'content' ] = rewrite_cached_urls ( $line [ 'content' ]);
2017-12-04 07:26:22 +00:00
if ( $vfeed_group_enabled && $line [ " feed_title " ]) {
if ( $feed_id != $vgroup_last_feed ) {
2013-03-27 09:34:04 +00:00
2017-12-04 07:26:22 +00:00
$vgroup_last_feed = $feed_id ;
2013-02-21 14:58:06 +00:00
2018-12-01 14:21:26 +00:00
$vf_catchup_link = " <a class='catchup' onclick='Feeds.catchupFeedInGroup( $feed_id );' href='#'> " . __ ( 'mark feed as read' ) . " </a> " ;
2013-02-21 14:58:06 +00:00
2017-12-04 07:26:22 +00:00
$feed_icon_src = Feeds :: getFeedIcon ( $feed_id );
$feed_icon_img = " <img class= \" tinyFeedIcon \" src= \" $feed_icon_src\ " > " ;
2013-02-21 14:58:06 +00:00
2018-11-30 12:48:17 +00:00
$reply [ 'content' ] .= " <div data-feed-id=' $feed_id ' class='feed-title'> " .
2017-12-04 07:26:22 +00:00
" <div style= \" float : right \" > $feed_icon_img </div> " .
2018-12-02 05:57:22 +00:00
" <a href= \" # \" class='title' onclick= \" Feeds.open( { feed: $feed_id }) \" > " .
2017-12-04 07:26:22 +00:00
$line [ " feed_title " ] . " </a> $vf_catchup_link </div> " ;
2013-02-21 14:58:06 +00:00
2017-12-04 07:26:22 +00:00
}
}
2013-02-23 12:01:51 +00:00
2018-11-30 10:56:33 +00:00
$content_encoded = htmlspecialchars ( $line [ " content " ]);
2018-11-30 10:26:41 +00:00
2018-11-30 22:03:01 +00:00
$expanded_class = get_pref ( " CDM_EXPANDED " ) ? " expanded " : " expandable " ;
$tmp_content = " <div class= \" cdm $expanded_class $hlc_suffix $class\ "
2018-11-30 10:26:41 +00:00
id = \ " RROW- $id\ " data - content = \ " $content_encoded\ " data - article - id = '$id' data - orig - feed - id = '$feed_id' $mouseover_attrs > " ;
2013-02-21 14:58:06 +00:00
2018-11-30 12:48:17 +00:00
$tmp_content .= " <div class= \" header \" > " ;
2018-12-05 10:58:18 +00:00
$tmp_content .= " <div class= \" left \" > " ;
2013-02-21 14:58:06 +00:00
2017-12-04 07:26:22 +00:00
$tmp_content .= " <input dojoType= \" dijit.form.CheckBox \"
2018-12-02 07:33:58 +00:00
type = \ " checkbox \" onclick= \" Headlines.onRowChecked(this) \"
2017-12-01 17:25:13 +00:00
class = 'rchk' > " ;
2013-02-21 14:58:06 +00:00
2017-12-04 07:26:22 +00:00
$tmp_content .= " $marked_pic " ;
$tmp_content .= " $published_pic " ;
2013-02-21 14:58:06 +00:00
2017-12-04 07:26:22 +00:00
$tmp_content .= " </div> " ;
2013-02-21 14:58:06 +00:00
2017-12-04 07:26:22 +00:00
if ( $highlight_words && count ( $highlight_words ) > 0 ) {
foreach ( $highlight_words as $word ) {
2017-12-15 05:33:59 +00:00
$word = preg_quote ( $word , " / " );
$line [ " title " ] = preg_replace ( " /( $word )/i " ,
2017-12-04 07:26:22 +00:00
" <span class= \" highlight \" > $ 1</span> " , $line [ " title " ]);
}
}
2013-02-21 14:58:06 +00:00
2017-12-04 07:26:22 +00:00
// data-article-id included for context menu
2018-11-30 11:39:06 +00:00
$tmp_content .= " <span
2018-12-01 14:54:16 +00:00
onclick = \ " return Headlines.click(event, $id ); \"
2017-12-01 17:25:13 +00:00
data - article - id = \ " $id\ "
2018-11-03 12:08:43 +00:00
class = \ " titleWrap hlMenuAttach $hlc_suffix\ " >
2017-12-01 17:25:13 +00:00
< a class = \ " title $hlc_suffix\ "
title = \ " " . htmlspecialchars ( $line [ " title " ]) . " \"
target = \ " _blank \" rel= \" noopener noreferrer \" href= \" " .
2017-12-04 07:26:22 +00:00
htmlspecialchars ( $line [ " link " ]) . " \" > " .
$line [ " title " ] .
" </a> <span class= \" author \" > $entry_author </span> " ;
2015-07-12 22:19:52 +00:00
2017-12-04 07:26:22 +00:00
$tmp_content .= $labels_str ;
2013-02-21 14:58:06 +00:00
2018-12-02 16:04:53 +00:00
if ( ! get_pref ( " CDM_EXPANDED " )) {
$tmp_content .= " <span class='collapse'>
< img src = \ " images/collapse.png \" onclick= \" return Article.cdmUnsetActive(event) \"
title = \ " " . __ ( " Collapse article " ) . " \" /></span> " ;
2018-12-04 07:47:50 +00:00
if ( get_pref ( 'SHOW_CONTENT_PREVIEW' )) {
$tmp_content .= " <span class='excerpt'> " . $line [ " content_preview " ] . " </span> " ;
}
2018-12-02 16:04:53 +00:00
}
2018-11-30 22:03:01 +00:00
2017-12-04 07:26:22 +00:00
$tmp_content .= " </span> " ;
2013-02-21 14:58:06 +00:00
2017-12-04 07:26:22 +00:00
if ( ! $vfeed_group_enabled ) {
if ( @ $line [ " feed_title " ]) {
$rgba = @ $rgba_cache [ $feed_id ];
2013-02-21 14:58:06 +00:00
2018-11-30 12:48:17 +00:00
$tmp_content .= " <div class= \" feed \" >
2017-12-01 17:25:13 +00:00
< a href = \ " # \" style= \" background-color: rgba( $rgba ,0.3) \"
2018-12-02 05:57:22 +00:00
onclick = \ " Feeds.open( { feed: $feed_id }) \" > " .
2017-12-04 07:26:22 +00:00
truncate_string ( $line [ " feed_title " ], 30 ) . " </a>
2017-12-01 17:25:13 +00:00
</ div > " ;
2017-12-04 07:26:22 +00:00
}
}
2013-02-21 14:58:06 +00:00
2017-12-04 07:26:22 +00:00
$tmp_content .= " <span class='updated' title=' $date_entered_fmt '> $updated_fmt </span> " ;
2013-07-31 12:41:06 +00:00
2018-12-05 06:08:02 +00:00
$tmp_content .= " <div class='right'> " ;
2017-12-04 07:26:22 +00:00
$tmp_content .= " $score_pic " ;
2013-03-16 12:59:31 +00:00
2017-12-04 07:26:22 +00:00
if ( ! get_pref ( " VFEED_GROUP_BY_FEED " ) && $line [ " feed_title " ]) {
$tmp_content .= " <span style= \" cursor : pointer \"
2017-12-01 17:25:13 +00:00
title = \ " " . htmlspecialchars ( $line [ " feed_title " ]) . " \"
2018-12-02 05:57:22 +00:00
onclick = \ " Feeds.open( { feed: $feed_id }) \" > $feed_icon_img </span> " ;
2017-12-04 07:26:22 +00:00
}
2018-11-30 12:48:17 +00:00
$tmp_content .= " </div> " ; //score wrapper2
2013-03-16 13:17:55 +00:00
2018-11-30 12:48:17 +00:00
$tmp_content .= " </div> " ; //header
2013-02-21 14:58:06 +00:00
2018-12-01 14:54:16 +00:00
$tmp_content .= " <div class= \" content \" onclick= \" return Headlines.click(event, $id , true); \" > " ;
2013-02-21 14:58:06 +00:00
2017-12-04 07:26:22 +00:00
$tmp_content .= " <div id= \" POSTNOTE- $id\ " > " ;
if ( $line [ 'note' ]) {
$tmp_content .= Article :: format_article_note ( $id , $line [ 'note' ]);
}
$tmp_content .= " </div> " ; //POSTNOTE
2013-02-21 14:58:06 +00:00
2017-12-04 07:26:22 +00:00
if ( ! $line [ 'lang' ]) $line [ 'lang' ] = 'en' ;
2013-02-21 14:58:06 +00:00
2018-11-30 10:51:54 +00:00
// this is filled from RROW data-content
2018-12-03 17:05:11 +00:00
$tmp_content .= " <div class= \" content-inner \" lang= \" " . $line [ 'lang' ] . " \" >
< img src = 'images/indicator_white.gif' >
</ div > " ;
$tmp_content .= " <div class= \" intermediate \" > " ;
2013-02-28 12:23:33 +00:00
2017-12-04 07:26:22 +00:00
if ( $line [ " orig_feed_id " ]) {
2013-07-31 07:57:11 +00:00
2017-12-04 07:26:22 +00:00
$ofgh = $this -> pdo -> prepare ( " SELECT * FROM ttrss_archived_feeds
2017-12-01 17:25:13 +00:00
WHERE id = ? AND owner_uid = ? " );
2017-12-04 07:26:22 +00:00
$ofgh -> execute ([ $line [ " orig_feed_id " ], $_SESSION [ 'uid' ]]);
2013-02-21 14:58:06 +00:00
2017-12-04 07:26:22 +00:00
if ( $tmp_line = $ofgh -> fetch ()) {
2013-02-21 14:58:06 +00:00
2017-12-04 07:26:22 +00:00
$tmp_content .= " <div clear='both'> " ;
$tmp_content .= __ ( " Originally from: " );
2013-02-21 14:58:06 +00:00
2017-12-04 07:26:22 +00:00
$tmp_content .= " " ;
2013-02-21 14:58:06 +00:00
2017-12-04 07:26:22 +00:00
$tmp_content .= " <a target='_blank' rel='noopener noreferrer'
2017-12-01 17:25:13 +00:00
href = ' " . htmlspecialchars($tmp_line[' site_url ']) . "' > " .
2017-12-04 07:26:22 +00:00
$tmp_line [ 'title' ] . " </a> " ;
2013-02-21 14:58:06 +00:00
2017-12-04 07:26:22 +00:00
$tmp_content .= " " ;
2013-02-21 14:58:06 +00:00
2017-12-04 07:26:22 +00:00
$tmp_content .= " <a target='_blank' rel='noopener noreferrer' href=' " . htmlspecialchars ( $tmp_line [ 'feed_url' ]) . " '> " ;
2013-02-21 14:58:06 +00:00
2017-12-04 07:26:22 +00:00
$tmp_content .= " </div> " ;
}
}
2013-02-21 14:58:06 +00:00
2017-12-04 07:26:22 +00:00
$always_display_enclosures = $line [ " always_display_enclosures " ];
$tmp_content .= Article :: format_article_enclosures ( $id , $always_display_enclosures ,
$line [ " content " ], $line [ " hide_images " ]);
2013-02-21 14:58:06 +00:00
2017-12-04 07:26:22 +00:00
$tmp_content .= " </div> " ; // cdmIntermediate
2015-08-12 05:29:09 +00:00
2018-11-30 12:48:17 +00:00
$tmp_content .= " <div class= \" footer \" onclick= \" event.stopPropagation() \" > " ;
2015-08-12 05:29:09 +00:00
2017-12-04 07:26:22 +00:00
foreach ( PluginHost :: getInstance () -> get_hooks ( PluginHost :: HOOK_ARTICLE_LEFT_BUTTON ) as $p ) {
$tmp_content .= $p -> hook_article_left_button ( $line );
}
2015-08-12 05:29:09 +00:00
2017-12-04 07:26:22 +00:00
$tags_str = Article :: format_tags_string ( $tags , $id );
2013-02-21 14:58:06 +00:00
2018-12-05 05:28:18 +00:00
$tmp_content .= " <div class='left'> " ;
2013-04-09 12:46:56 +00:00
2017-12-04 07:26:22 +00:00
$tmp_content .= " <img src='images/tag.png' alt='Tags' title='Tags'>
2017-12-01 17:25:13 +00:00
< span id = \ " ATSTR- $id\ " > $tags_str </ span >
< a title = \ " " . __ ( 'Edit tags for this article' ) . " \"
2018-12-02 22:02:03 +00:00
href = \ " # \" onclick= \" Article.editTags( $id ) \" >(+)</a> " ;
2013-02-21 14:58:06 +00:00
2017-12-04 07:26:22 +00:00
$num_comments = ( int ) $line [ " num_comments " ];
$entry_comments = " " ;
2015-08-11 12:29:27 +00:00
2017-12-04 07:26:22 +00:00
if ( $num_comments > 0 ) {
if ( $line [ " comments " ]) {
$comments_url = htmlspecialchars ( $line [ " comments " ]);
} else {
$comments_url = htmlspecialchars ( $line [ " link " ]);
}
2018-11-30 14:22:30 +00:00
$entry_comments = " <a class= \" comments \"
2017-12-01 17:25:13 +00:00
target = '_blank' rel = 'noopener noreferrer' href = \ " $comments_url\ " > $num_comments " .
2017-12-04 07:26:22 +00:00
_ngettext ( " comment " , " comments " , $num_comments ) . " </a> " ;
2013-02-21 14:58:06 +00:00
2017-12-04 07:26:22 +00:00
} else {
if ( $line [ " comments " ] && $line [ " link " ] != $line [ " comments " ]) {
2018-11-30 14:22:30 +00:00
$entry_comments = " <a class= \" comments \" target='_blank' rel='noopener noreferrer' href= \" " . htmlspecialchars ( $line [ " comments " ]) . " \" > " . __ ( " comments " ) . " </a> " ;
2017-12-04 07:26:22 +00:00
}
}
2013-02-21 14:58:06 +00:00
2017-12-04 07:26:22 +00:00
if ( $entry_comments ) $tmp_content .= " ( $entry_comments ) " ;
2013-09-02 08:58:14 +00:00
2018-12-05 05:28:18 +00:00
$tmp_content .= " </div> " ;
$tmp_content .= " <div class='right'> " ;
2013-02-21 14:58:06 +00:00
2017-12-04 07:26:22 +00:00
foreach ( PluginHost :: getInstance () -> get_hooks ( PluginHost :: HOOK_ARTICLE_BUTTON ) as $p ) {
$tmp_content .= $p -> hook_article_button ( $line );
}
2013-02-21 14:58:06 +00:00
2017-12-04 07:26:22 +00:00
$tmp_content .= " </div> " ; // buttons
2013-02-21 14:58:06 +00:00
2018-11-30 12:48:17 +00:00
$tmp_content .= " </div> " ; // cdm footer
2017-12-04 07:26:22 +00:00
$tmp_content .= " </div> " ; // cdmContent
$tmp_content .= " </div> " ; // RROW.cdm
2013-04-09 12:13:32 +00:00
2017-12-04 07:26:22 +00:00
foreach ( PluginHost :: getInstance () -> get_hooks ( PluginHost :: HOOK_FORMAT_ARTICLE_CDM ) as $p ) {
$tmp_content = $p -> hook_format_article_cdm ( $tmp_content , $line );
}
2013-02-21 14:58:06 +00:00
2017-12-04 07:26:22 +00:00
$reply [ 'content' ] .= $tmp_content ;
}
2013-02-21 14:58:06 +00:00
2017-12-04 07:26:22 +00:00
++ $lnum ;
}
2017-12-01 17:25:13 +00:00
}
2013-02-21 14:58:06 +00:00
2017-12-01 17:25:13 +00:00
if ( $_REQUEST [ " debug " ]) $timing_info = print_checkpoint ( " PE " , $timing_info );
2013-02-21 14:58:06 +00:00
2017-12-01 17:25:13 +00:00
if ( ! $headlines_count ) {
2013-02-21 14:58:06 +00:00
2017-12-01 17:25:13 +00:00
if ( ! is_numeric ( $result )) {
2013-02-21 14:58:06 +00:00
2017-12-01 17:25:13 +00:00
switch ( $view_mode ) {
case " unread " :
$message = __ ( " No unread articles found to display. " );
break ;
case " updated " :
$message = __ ( " No updated articles found to display. " );
break ;
case " marked " :
$message = __ ( " No starred articles found to display. " );
break ;
default :
if ( $feed < LABEL_BASE_INDEX ) {
$message = __ ( " No articles found to display. You can assign articles to labels manually from article header context menu (applies to all selected articles) or use a filter. " );
} else {
$message = __ ( " No articles found to display. " );
}
}
2013-02-21 14:58:06 +00:00
2017-12-01 17:25:13 +00:00
if ( ! $offset && $message ) {
$reply [ 'content' ] = " <div class='whiteBox'> $message " ;
2013-02-21 14:58:06 +00:00
2017-12-01 17:25:13 +00:00
$reply [ 'content' ] .= " <p><span class= \" insensitive \" > " ;
2013-02-21 14:58:06 +00:00
2017-12-01 17:25:13 +00:00
$sth = $this -> pdo -> prepare ( " SELECT " . SUBSTRING_FOR_DATE . " (MAX(last_updated), 1, 19) AS last_updated FROM ttrss_feeds
WHERE owner_uid = ? " );
$sth -> execute ([ $_SESSION [ 'uid' ]]);
$row = $sth -> fetch ();
2013-02-21 14:58:06 +00:00
2017-12-01 17:25:13 +00:00
$last_updated = make_local_datetime ( $row [ " last_updated " ], false );
2013-02-21 14:58:06 +00:00
2017-12-01 17:25:13 +00:00
$reply [ 'content' ] .= sprintf ( __ ( " Feeds last updated at %s " ), $last_updated );
2013-02-21 14:58:06 +00:00
2017-12-01 17:25:13 +00:00
$sth = $this -> pdo -> prepare ( " SELECT COUNT(id) AS num_errors
FROM ttrss_feeds WHERE last_error != '' AND owner_uid = ? " );
$sth -> execute ([ $_SESSION [ 'uid' ]]);
$row = $sth -> fetch ();
2013-02-21 14:58:06 +00:00
2017-12-01 17:25:13 +00:00
$num_errors = $row [ " num_errors " ];
2013-02-21 14:58:06 +00:00
2017-12-01 17:25:13 +00:00
if ( $num_errors > 0 ) {
$reply [ 'content' ] .= " <br/> " ;
2018-12-01 15:25:32 +00:00
$reply [ 'content' ] .= " <a class= \" insensitive \" href= \" # \" onclick= \" CommonDialogs.showFeedsWithErrors() \" > " .
2017-12-01 17:25:13 +00:00
__ ( 'Some feeds have update errors (click for details)' ) . " </a> " ;
}
$reply [ 'content' ] .= " </span></p></div> " ;
2015-07-13 10:29:13 +00:00
2017-12-01 17:25:13 +00:00
}
} else if ( is_numeric ( $result ) && $result == - 1 ) {
$reply [ 'first_id_changed' ] = true ;
2013-02-21 14:58:06 +00:00
}
}
if ( $_REQUEST [ " debug " ]) $timing_info = print_checkpoint ( " H2 " , $timing_info );
return array ( $topmost_article_ids , $headlines_count , $feed , $disable_cache ,
$vgroup_last_feed , $reply );
}
function catchupAll () {
2017-12-01 16:42:02 +00:00
$sth = $this -> pdo -> prepare ( " UPDATE ttrss_user_entries SET
last_read = NOW (), unread = false WHERE unread = true AND owner_uid = ? " );
$sth -> execute ([ $_SESSION [ 'uid' ]]);
2017-05-04 12:22:57 +00:00
CCache :: zero_all ( $_SESSION [ " uid " ]);
2013-02-21 14:58:06 +00:00
}
function view () {
2013-02-27 18:16:58 +00:00
$timing_info = microtime ( true );
2013-02-21 14:58:06 +00:00
$reply = array ();
if ( $_REQUEST [ " debug " ]) $timing_info = print_checkpoint ( " 0 " , $timing_info );
2017-12-01 17:26:51 +00:00
$feed = $_REQUEST [ " feed " ];
$method = $_REQUEST [ " m " ];
$view_mode = $_REQUEST [ " view_mode " ];
2013-04-02 11:32:47 +00:00
$limit = 30 ;
2013-02-21 14:58:06 +00:00
@ $cat_view = $_REQUEST [ " cat " ] == " true " ;
2017-12-01 17:26:51 +00:00
@ $next_unread_feed = $_REQUEST [ " nuf " ];
@ $offset = $_REQUEST [ " skip " ];
@ $vgroup_last_feed = $_REQUEST [ " vgrlf " ];
$order_by = $_REQUEST [ " order_by " ];
$check_first_id = $_REQUEST [ " fid " ];
2013-02-21 14:58:06 +00:00
if ( is_numeric ( $feed )) $feed = ( int ) $feed ;
/* Feed - 5 is a special case : it is used to display auxiliary information
* when there ' s nothing to load - e . g . no stuff in fresh feed */
if ( $feed == - 5 ) {
2013-04-17 12:23:15 +00:00
print json_encode ( $this -> generate_dashboard_feed ());
2013-02-21 14:58:06 +00:00
return ;
}
2017-12-01 16:42:02 +00:00
$sth = false ;
2013-03-27 05:40:07 +00:00
if ( $feed < LABEL_BASE_INDEX ) {
2017-12-01 16:42:02 +00:00
2017-05-04 12:57:40 +00:00
$label_feed = Labels :: feed_to_label_id ( $feed );
2017-12-01 16:42:02 +00:00
$sth = $this -> pdo -> prepare ( " SELECT id FROM ttrss_labels2 WHERE
id = ? AND owner_uid = ? " );
$sth -> execute ([ $label_feed , $_SESSION [ 'uid' ]]);
2013-02-21 14:58:06 +00:00
} else if ( ! $cat_view && is_numeric ( $feed ) && $feed > 0 ) {
2017-12-01 16:42:02 +00:00
$sth = $this -> pdo -> prepare ( " SELECT id FROM ttrss_feeds WHERE
id = ? AND owner_uid = ? " );
$sth -> execute ([ $feed , $_SESSION [ 'uid' ]]);
2013-02-21 14:58:06 +00:00
} else if ( $cat_view && is_numeric ( $feed ) && $feed > 0 ) {
2017-12-01 16:42:02 +00:00
$sth = $this -> pdo -> prepare ( " SELECT id FROM ttrss_feed_categories WHERE
id = ? AND owner_uid = ? " );
$sth -> execute ([ $feed , $_SESSION [ 'uid' ]]);
2013-02-21 14:58:06 +00:00
}
2017-12-01 16:42:02 +00:00
if ( $sth && ! $sth -> fetch ()) {
2013-04-17 14:34:18 +00:00
print json_encode ( $this -> generate_error_feed ( __ ( " Feed not found. " )));
2013-02-21 14:58:06 +00:00
return ;
}
/* Updating a label ccache means recalculating all of the caches
* so for performance reasons we don ' t do that here */
if ( $feed >= 0 ) {
2017-05-04 12:22:57 +00:00
CCache :: update ( $feed , $_SESSION [ " uid " ], $cat_view );
2013-02-21 14:58:06 +00:00
}
2013-04-17 14:34:18 +00:00
set_pref ( " _DEFAULT_VIEW_MODE " , $view_mode );
set_pref ( " _DEFAULT_VIEW_ORDER_BY " , $order_by );
2013-02-21 14:58:06 +00:00
2013-03-22 08:37:42 +00:00
/* bump login timestamp if needed */
if ( time () - $_SESSION [ " last_login_update " ] > 3600 ) {
2017-12-01 16:42:02 +00:00
$sth = $this -> pdo -> prepare ( " UPDATE ttrss_users SET last_login = NOW() WHERE id = ? " );
$sth -> execute ([ $_SESSION [ 'uid' ]]);
2013-03-22 08:37:42 +00:00
$_SESSION [ " last_login_update " ] = time ();
}
2013-02-21 14:58:06 +00:00
if ( ! $cat_view && is_numeric ( $feed ) && $feed > 0 ) {
2017-12-01 16:42:02 +00:00
$sth = $this -> pdo -> prepare ( " UPDATE ttrss_feeds SET last_viewed = NOW()
WHERE id = ? AND owner_uid = ? " );
$sth -> execute ([ $feed , $_SESSION [ 'uid' ]]);
2013-02-21 14:58:06 +00:00
}
$reply [ 'headlines' ] = array ();
$override_order = false ;
2015-11-21 19:20:00 +00:00
$skip_first_id_check = false ;
2013-02-21 14:58:06 +00:00
switch ( $order_by ) {
2013-04-04 16:44:55 +00:00
case " title " :
2017-10-09 15:23:13 +00:00
$override_order = " ttrss_entries.title, date_entered, updated " ;
2013-04-04 16:44:55 +00:00
break ;
case " date_reverse " :
2013-07-06 08:03:01 +00:00
$override_order = " score DESC, date_entered, updated " ;
2015-11-21 19:20:00 +00:00
$skip_first_id_check = true ;
2013-04-04 16:44:55 +00:00
break ;
case " feed_dates " :
$override_order = " updated DESC " ;
break ;
2013-02-21 14:58:06 +00:00
}
if ( $_REQUEST [ " debug " ]) $timing_info = print_checkpoint ( " 04 " , $timing_info );
$ret = $this -> format_headlines_list ( $feed , $method ,
2017-04-26 12:29:22 +00:00
$view_mode , $limit , $cat_view , $offset ,
2015-11-21 19:20:00 +00:00
$vgroup_last_feed , $override_order , true , $check_first_id , $skip_first_id_check );
2013-02-21 14:58:06 +00:00
2013-02-28 12:09:41 +00:00
//$topmost_article_ids = $ret[0];
2013-02-21 14:58:06 +00:00
$headlines_count = $ret [ 1 ];
2014-02-19 11:42:52 +00:00
/* $returned_feed = $ret[2]; */
2013-02-21 14:58:06 +00:00
$disable_cache = $ret [ 3 ];
$vgroup_last_feed = $ret [ 4 ];
2015-07-12 09:01:34 +00:00
//$reply['headlines']['content'] =& $ret[5]['content'];
//$reply['headlines']['toolbar'] =& $ret[5]['toolbar'];
2015-12-04 06:29:58 +00:00
$reply [ 'headlines' ] = $ret [ 5 ];
2015-07-12 09:01:34 +00:00
if ( ! $next_unread_feed )
$reply [ 'headlines' ][ 'id' ] = $feed ;
else
$reply [ 'headlines' ][ 'id' ] = $next_unread_feed ;
$reply [ 'headlines' ][ 'is_cat' ] = ( bool ) $cat_view ;
2013-02-21 14:58:06 +00:00
if ( $_REQUEST [ " debug " ]) $timing_info = print_checkpoint ( " 05 " , $timing_info );
$reply [ 'headlines-info' ] = array ( " count " => ( int ) $headlines_count ,
" vgroup_last_feed " => $vgroup_last_feed ,
" disable_cache " => ( bool ) $disable_cache );
if ( $_REQUEST [ " debug " ]) $timing_info = print_checkpoint ( " 30 " , $timing_info );
2013-04-17 12:23:15 +00:00
$reply [ 'runtime-info' ] = make_runtime_info ();
2013-02-21 14:58:06 +00:00
print json_encode ( $reply );
}
2013-04-17 12:23:15 +00:00
private function generate_dashboard_feed () {
2013-02-21 14:58:06 +00:00
$reply = array ();
$reply [ 'headlines' ][ 'id' ] = - 5 ;
$reply [ 'headlines' ][ 'is_cat' ] = false ;
$reply [ 'headlines' ][ 'toolbar' ] = '' ;
2015-07-13 19:01:29 +00:00
$reply [ 'headlines' ][ 'content' ] = " <div class='whiteBox'> " . __ ( 'No feed selected.' );
2015-07-13 15:43:54 +00:00
2015-07-13 19:01:29 +00:00
$reply [ 'headlines' ][ 'content' ] .= " <p><span class= \" insensitive \" > " ;
2013-02-21 14:58:06 +00:00
2017-12-01 16:42:02 +00:00
$sth = $this -> pdo -> prepare ( " SELECT " . SUBSTRING_FOR_DATE . " (MAX(last_updated), 1, 19) AS last_updated FROM ttrss_feeds
WHERE owner_uid = ? " );
$sth -> execute ([ $_SESSION [ 'uid' ]]);
$row = $sth -> fetch ();
2013-02-21 14:58:06 +00:00
2017-12-01 16:42:02 +00:00
$last_updated = make_local_datetime ( $row [ " last_updated " ], false );
2013-02-21 14:58:06 +00:00
2015-07-13 19:01:29 +00:00
$reply [ 'headlines' ][ 'content' ] .= sprintf ( __ ( " Feeds last updated at %s " ), $last_updated );
2013-02-21 14:58:06 +00:00
2017-12-01 16:42:02 +00:00
$sth = $this -> pdo -> prepare ( " SELECT COUNT(id) AS num_errors
FROM ttrss_feeds WHERE last_error != '' AND owner_uid = ? " );
$sth -> execute ([ $_SESSION [ 'uid' ]]);
$row = $sth -> fetch ();
2013-02-21 14:58:06 +00:00
2017-12-01 16:42:02 +00:00
$num_errors = $row [ " num_errors " ];
2013-02-21 14:58:06 +00:00
if ( $num_errors > 0 ) {
2015-07-13 19:01:29 +00:00
$reply [ 'headlines' ][ 'content' ] .= " <br/> " ;
2018-12-01 15:25:32 +00:00
$reply [ 'headlines' ][ 'content' ] .= " <a class= \" insensitive \" href= \" # \" onclick= \" CommonDialogs.showFeedsWithErrors() \" > " .
2013-02-21 14:58:06 +00:00
__ ( 'Some feeds have update errors (click for details)' ) . " </a> " ;
}
2015-07-13 19:01:29 +00:00
$reply [ 'headlines' ][ 'content' ] .= " </span></p> " ;
2013-02-21 14:58:06 +00:00
$reply [ 'headlines-info' ] = array ( " count " => 0 ,
" vgroup_last_feed " => '' ,
" unread " => 0 ,
" disable_cache " => true );
return $reply ;
}
2013-04-17 14:34:18 +00:00
private function generate_error_feed ( $error ) {
2013-02-21 14:58:06 +00:00
$reply = array ();
2015-07-13 19:04:21 +00:00
$reply [ 'headlines' ][ 'id' ] = - 7 ;
2013-02-21 14:58:06 +00:00
$reply [ 'headlines' ][ 'is_cat' ] = false ;
$reply [ 'headlines' ][ 'toolbar' ] = '' ;
$reply [ 'headlines' ][ 'content' ] = " <div class='whiteBox'> " . $error . " </div> " ;
$reply [ 'headlines-info' ] = array ( " count " => 0 ,
" vgroup_last_feed " => '' ,
" unread " => 0 ,
" disable_cache " => true );
return $reply ;
}
2013-04-01 07:14:27 +00:00
function quickAddFeed () {
2017-12-11 15:43:53 +00:00
print " <form onsubmit='return false'> " ;
2017-02-10 11:36:21 +00:00
print_hidden ( " op " , " rpc " );
print_hidden ( " method " , " addfeed " );
2013-04-01 07:14:27 +00:00
2017-01-28 09:45:49 +00:00
print " <div id='fadd_error_message' style='display : none' class='alert alert-danger'></div> " ;
2013-10-02 11:24:08 +00:00
print " <div id='fadd_multiple_notify' style='display : none'> " ;
print_notice ( " Provided URL is a HTML page referencing multiple feeds, please select required feed from the dropdown menu below. " );
print " <p></div> " ;
2013-04-01 07:14:27 +00:00
print " <div class= \" dlgSec \" > " . __ ( " Feed or site URL " ) . " </div> " ;
print " <div class= \" dlgSecCont \" > " ;
print " <div style='float : right'>
< img style = 'display : none'
id = 'feed_add_spinner' src = 'images/indicator_white.gif' ></ div > " ;
print " <input style= \" font-size : 16px; width : 20em; \"
placeHolder = \ " " . __ ( " Feed or site URL " ) . " \"
dojoType = \ " dijit.form.ValidationTextBox \" required= \" 1 \" name= \" feed \" id= \" feedDlg_feedUrl \" > " ;
print " <hr/> " ;
2013-04-17 14:34:18 +00:00
if ( get_pref ( 'ENABLE_FEED_CATS' )) {
2013-04-01 07:14:27 +00:00
print __ ( 'Place in category:' ) . " " ;
2013-04-17 14:34:18 +00:00
print_feed_cat_select ( " cat " , false , 'dojoType="dijit.form.Select"' );
2013-04-01 07:14:27 +00:00
}
print " </div> " ;
print ' < div id = " feedDlg_feedsContainer " style = " display : none " >
< div class = " dlgSec " > ' . __(' Available feeds ') . ' </ div >
< div class = " dlgSecCont " > ' .
' < select id = " feedDlg_feedContainerSelect "
dojoType = " dijit.form.Select " size = " 3 " >
< script type = " dojo/method " event = " onChange " args = " value " >
dijit . byId ( " feedDlg_feedUrl " ) . attr ( " value " , value );
</ script >
</ select > ' .
'</div></div>' ;
print " <div id='feedDlg_loginContainer' style='display : none'>
< div class = \ " dlgSec \" > " . __ ( " Authentication " ) . " </div>
< div class = \ " dlgSecCont \" > " .
" <input dojoType= \" dijit.form.TextBox \" name='login' \"
placeHolder = \ " " . __ ( " Login " ) . " \"
2016-05-18 11:48:51 +00:00
autocomplete = \ " new-password \"
2013-04-01 07:14:27 +00:00
style = \ " width : 10em; \" > " .
" <input
placeHolder = \ " " . __ ( " Password " ) . " \"
dojoType = \ " dijit.form.TextBox \" type='password'
2016-05-18 11:48:51 +00:00
autocomplete = \ " new-password \"
2013-04-01 07:14:27 +00:00
style = \ " width : 10em; \" name='pass' \" >
</ div ></ div > " ;
print " <div style= \" clear : both \" >
< input type = \ " checkbox \" name= \" need_auth \" dojoType= \" dijit.form.CheckBox \" id= \" feedDlg_loginCheck \"
2018-12-01 08:18:35 +00:00
onclick = 'displayIfChecked(this, \"feedDlg_loginContainer\")' >
2013-04-01 07:14:27 +00:00
< label for = \ " feedDlg_loginCheck \" > " .
__ ( 'This feed requires authentication.' ) . " </div> " ;
print " <div class= \" dlgButtons \" >
2018-12-04 16:03:42 +00:00
< button dojoType = \ " dijit.form.Button \" class= \" alt-primary \" type= \" submit \" onclick= \" return dijit.byId('feedAddDlg').execute() \" > " . __ ( 'Subscribe' ) . " </button> " ;
2013-04-01 07:14:27 +00:00
if ( ! ( defined ( '_DISABLE_FEED_BROWSER' ) && _DISABLE_FEED_BROWSER )) {
2018-12-01 15:25:32 +00:00
print " <button dojoType= \" dijit.form.Button \" onclick= \" return CommonDialogs.feedBrowser() \" > " . __ ( 'More feeds' ) . " </button> " ;
2013-04-01 07:14:27 +00:00
}
print " <button dojoType= \" dijit.form.Button \" onclick= \" return dijit.byId('feedAddDlg').hide() \" > " . __ ( 'Cancel' ) . " </button>
</ div > " ;
2017-12-11 15:43:53 +00:00
print " </form> " ;
2013-04-01 07:14:27 +00:00
//return;
}
function feedBrowser () {
if ( defined ( '_DISABLE_FEED_BROWSER' ) && _DISABLE_FEED_BROWSER ) return ;
2017-12-01 17:26:51 +00:00
$browser_search = $_REQUEST [ " search " ];
2013-04-01 07:14:27 +00:00
2017-02-10 11:36:21 +00:00
print_hidden ( " op " , " rpc " );
print_hidden ( " method " , " updateFeedBrowser " );
2013-04-01 07:14:27 +00:00
print " <div dojoType= \" dijit.Toolbar \" >
< div style = 'float : right' >
< img style = 'display : none'
id = 'feed_browser_spinner' src = 'images/indicator_white.gif' >
< input name = \ " search \" dojoType= \" dijit.form.TextBox \" size= \" 20 \" type= \" search \"
onchange = \ " dijit.byId('feedBrowserDlg').update() \" value= \" $browser_search\ " >
< button dojoType = \ " dijit.form.Button \" onclick= \" dijit.byId('feedBrowserDlg').update() \" > " . __ ( 'Search' ) . " </button>
</ div > " ;
print " <select name= \" mode \" dojoType= \" dijit.form.Select \" onchange= \" dijit.byId('feedBrowserDlg').update() \" >
< option value = '1' > " . __('Popular feeds') . " </ option >
< option value = '2' > " . __('Feed archive') . " </ option >
</ select > " ;
print __ ( " limit: " );
print " <select dojoType= \" dijit.form.Select \" name= \" limit \" onchange= \" dijit.byId('feedBrowserDlg').update() \" > " ;
foreach ( array ( 25 , 50 , 100 , 200 ) as $l ) {
2014-02-19 11:42:52 +00:00
//$issel = ($l == $limit) ? "selected=\"1\"" : "";
print " <option value= \" $l\ " > $l </ option > " ;
2013-04-01 07:14:27 +00:00
}
print " </select> " ;
print " </div> " ;
require_once " feedbrowser.php " ;
print " <ul class='browseFeedList' id='browseFeedList'> " ;
2014-02-19 11:42:52 +00:00
print make_feed_browser ( " " , 25 );
2013-04-01 07:14:27 +00:00
print " </ul> " ;
print " <div align='center'>
< button dojoType = \ " dijit.form.Button \" onclick= \" dijit.byId('feedBrowserDlg').execute() \" > " . __ ( 'Subscribe' ) . " </button>
< button dojoType = \ " dijit.form.Button \" style='display : none' id='feed_archive_remove' onclick= \" dijit.byId('feedBrowserDlg').removeFromArchive() \" > " . __ ( 'Remove' ) . " </button>
< button dojoType = \ " dijit.form.Button \" onclick= \" dijit.byId('feedBrowserDlg').hide() \" > " . __ ( 'Cancel' ) . " </button></div> " ;
}
function search () {
2017-12-01 17:26:51 +00:00
$this -> params = explode ( " : " , $_REQUEST [ " param " ], 2 );
2013-04-01 07:14:27 +00:00
$active_feed_id = sprintf ( " %d " , $this -> params [ 0 ]);
$is_cat = $this -> params [ 1 ] != " false " ;
2017-12-11 15:14:45 +00:00
print " <form onsubmit='return false;'> " ;
2013-04-01 07:14:27 +00:00
print " <div class= \" dlgSec \" > " . __ ( 'Look for' ) . " </div> " ;
print " <div class= \" dlgSecCont \" > " ;
print " <input dojoType= \" dijit.form.ValidationTextBox \"
style = \ " font-size : 16px; width : 20em; \"
required = \ " 1 \" name= \" query \" type= \" search \" value=''> " ;
move the following to Feeds:
+ static function catchup_feed($feed, $cat_view, $owner_uid = false, $mode = 'all', $search = false) {
+ static function getFeedArticles($feed, $is_cat = false, $unread_only = false,
+ static function subscribe_to_feed($url, $cat_id = 0,
+ static function getFeedIcon($id) {
+ static function getFeedTitle($id, $cat = false) {
+ static function getCategoryUnread($cat, $owner_uid = false) {
+ static function getCategoryChildrenUnread($cat, $owner_uid = false) {
2017-05-04 11:50:56 +00:00
print " <hr/><span style='float : right'> " . T_sprintf ( 'in %s' , $this -> getFeedTitle ( $active_feed_id , $is_cat )) . " </span> " ;
2013-04-01 07:14:27 +00:00
2015-08-04 10:53:48 +00:00
if ( DB_TYPE == " pgsql " ) {
print " <hr/> " ;
print_select ( " search_language " , " " , Pref_Feeds :: $feed_languages ,
" dojoType='dijit.form.Select' title= \" " . __ ( 'Used for word stemming' ) . " \" " );
}
2013-04-01 07:14:27 +00:00
print " </div> " ;
print " <div class= \" dlgButtons \" > " ;
2014-04-15 04:18:33 +00:00
if ( count ( PluginHost :: getInstance () -> get_hooks ( PluginHost :: HOOK_SEARCH )) == 0 ) {
2013-04-01 07:14:27 +00:00
print " <div style= \" float : left \" >
2013-09-02 09:54:41 +00:00
< a class = \ " visibleLink \" target= \" _blank \" href= \" http://tt-rss.org/wiki/SearchSyntax \" > " . __ ( " Search syntax " ) . " </a>
2013-04-01 07:14:27 +00:00
</ div > " ;
}
2018-12-04 16:03:42 +00:00
print " <button dojoType= \" dijit.form.Button \" type= \" submit \" class= \" alt-primary \" onclick= \" dijit.byId('searchDlg').execute() \" > " . __ ( 'Search' ) . " </button>
2013-04-01 07:14:27 +00:00
< button dojoType = \ " dijit.form.Button \" onclick= \" dijit.byId('searchDlg').hide() \" > " . __ ( 'Cancel' ) . " </button>
</ div > " ;
2017-12-11 15:14:45 +00:00
print " </form> " ;
2013-04-01 07:14:27 +00:00
}
2015-06-12 10:06:36 +00:00
function update_debugger () {
header ( " Content-type: text/html " );
2018-11-30 05:34:29 +00:00
Debug :: set_enabled ( true );
Debug :: set_loglevel ( $_REQUEST [ " xdebug " ]);
2015-06-12 10:06:36 +00:00
$feed_id = ( int ) $_REQUEST [ " feed_id " ];
@ $do_update = $_REQUEST [ " action " ] == " do_update " ;
$csrf_token = $_REQUEST [ " csrf_token " ];
2017-12-03 10:35:18 +00:00
$sth = $this -> pdo -> prepare ( " SELECT id FROM ttrss_feeds WHERE id = ? AND owner_uid = ? " );
$sth -> execute ([ $feed_id , $_SESSION [ 'uid' ]]);
if ( ! $sth -> fetch ()) {
print " Access denied. " ;
return ;
}
2015-06-12 10:06:36 +00:00
$refetch_checked = isset ( $_REQUEST [ " force_refetch " ]) ? " checked " : " " ;
$rehash_checked = isset ( $_REQUEST [ " force_rehash " ]) ? " checked " : " " ;
?>
< html >
< head >
2017-12-03 10:25:34 +00:00
< ? php echo stylesheet_tag ( " css/default.css " ) ?>
2015-06-12 10:06:36 +00:00
< title > Feed Debugger </ title >
</ head >
2017-12-03 10:25:34 +00:00
< body class = " small_margins ttrss_utility claro " >
move the following to Feeds:
+ static function catchup_feed($feed, $cat_view, $owner_uid = false, $mode = 'all', $search = false) {
+ static function getFeedArticles($feed, $is_cat = false, $unread_only = false,
+ static function subscribe_to_feed($url, $cat_id = 0,
+ static function getFeedIcon($id) {
+ static function getFeedTitle($id, $cat = false) {
+ static function getCategoryUnread($cat, $owner_uid = false) {
+ static function getCategoryChildrenUnread($cat, $owner_uid = false) {
2017-05-04 11:50:56 +00:00
< h1 > Feed Debugger : < ? php echo " $feed_id : " . $this -> getFeedTitle ( $feed_id ) ?> </h1>
2015-06-12 10:06:36 +00:00
< form method = " GET " action = " " >
< input type = " hidden " name = " op " value = " feeds " >
< input type = " hidden " name = " method " value = " update_debugger " >
< input type = " hidden " name = " xdebug " value = " 1 " >
< input type = " hidden " name = " csrf_token " value = " <?php echo $csrf_token ?> " >
< input type = " hidden " name = " action " value = " do_update " >
< input type = " hidden " name = " feed_id " value = " <?php echo $feed_id ?> " >
< input type = " checkbox " name = " force_refetch " value = " 1 " < ? php echo $refetch_checked ?> > Force refetch<br/>
< input type = " checkbox " name = " force_rehash " value = " 1 " < ? php echo $rehash_checked ?> > Force rehash<br/>
< p />< button type = " submit " > Continue </ button >
</ form >
< hr >
< pre >< ? php
if ( $do_update ) {
2017-05-05 15:10:07 +00:00
RSSUtils :: update_rss_feed ( $feed_id , true );
2015-06-12 10:06:36 +00:00
}
?> </pre>
2013-04-01 07:14:27 +00:00
2015-06-12 10:06:36 +00:00
</ body >
</ html >
< ? php
}
2017-05-04 11:26:44 +00:00
move the following to Feeds:
+ static function catchup_feed($feed, $cat_view, $owner_uid = false, $mode = 'all', $search = false) {
+ static function getFeedArticles($feed, $is_cat = false, $unread_only = false,
+ static function subscribe_to_feed($url, $cat_id = 0,
+ static function getFeedIcon($id) {
+ static function getFeedTitle($id, $cat = false) {
+ static function getCategoryUnread($cat, $owner_uid = false) {
+ static function getCategoryChildrenUnread($cat, $owner_uid = false) {
2017-05-04 11:50:56 +00:00
static function catchup_feed ( $feed , $cat_view , $owner_uid = false , $mode = 'all' , $search = false ) {
if ( ! $owner_uid ) $owner_uid = $_SESSION [ 'uid' ];
2017-12-01 16:42:02 +00:00
$pdo = Db :: pdo ();
move the following to Feeds:
+ static function catchup_feed($feed, $cat_view, $owner_uid = false, $mode = 'all', $search = false) {
+ static function getFeedArticles($feed, $is_cat = false, $unread_only = false,
+ static function subscribe_to_feed($url, $cat_id = 0,
+ static function getFeedIcon($id) {
+ static function getFeedTitle($id, $cat = false) {
+ static function getCategoryUnread($cat, $owner_uid = false) {
+ static function getCategoryChildrenUnread($cat, $owner_uid = false) {
2017-05-04 11:50:56 +00:00
// Todo: all this interval stuff needs some generic generator function
$search_qpart = is_array ( $search ) && $search [ 0 ] ? search_to_sql ( $search [ 0 ], $search [ 1 ])[ 0 ] : 'true' ;
switch ( $mode ) {
case " 1day " :
if ( DB_TYPE == " pgsql " ) {
$date_qpart = " date_entered < NOW() - INTERVAL '1 day' " ;
} else {
$date_qpart = " date_entered < DATE_SUB(NOW(), INTERVAL 1 DAY) " ;
}
break ;
case " 1week " :
if ( DB_TYPE == " pgsql " ) {
$date_qpart = " date_entered < NOW() - INTERVAL '1 week' " ;
} else {
$date_qpart = " date_entered < DATE_SUB(NOW(), INTERVAL 1 WEEK) " ;
}
break ;
case " 2week " :
if ( DB_TYPE == " pgsql " ) {
$date_qpart = " date_entered < NOW() - INTERVAL '2 week' " ;
} else {
$date_qpart = " date_entered < DATE_SUB(NOW(), INTERVAL 2 WEEK) " ;
}
break ;
default :
$date_qpart = " true " ;
}
if ( is_numeric ( $feed )) {
if ( $cat_view ) {
if ( $feed >= 0 ) {
if ( $feed > 0 ) {
2017-05-04 12:13:02 +00:00
$children = Feeds :: getChildCategories ( $feed , $owner_uid );
move the following to Feeds:
+ static function catchup_feed($feed, $cat_view, $owner_uid = false, $mode = 'all', $search = false) {
+ static function getFeedArticles($feed, $is_cat = false, $unread_only = false,
+ static function subscribe_to_feed($url, $cat_id = 0,
+ static function getFeedIcon($id) {
+ static function getFeedTitle($id, $cat = false) {
+ static function getCategoryUnread($cat, $owner_uid = false) {
+ static function getCategoryChildrenUnread($cat, $owner_uid = false) {
2017-05-04 11:50:56 +00:00
array_push ( $children , $feed );
2017-12-17 13:24:13 +00:00
$children = array_map ( " intval " , $children );
move the following to Feeds:
+ static function catchup_feed($feed, $cat_view, $owner_uid = false, $mode = 'all', $search = false) {
+ static function getFeedArticles($feed, $is_cat = false, $unread_only = false,
+ static function subscribe_to_feed($url, $cat_id = 0,
+ static function getFeedIcon($id) {
+ static function getFeedTitle($id, $cat = false) {
+ static function getCategoryUnread($cat, $owner_uid = false) {
+ static function getCategoryChildrenUnread($cat, $owner_uid = false) {
2017-05-04 11:50:56 +00:00
$children = join ( " , " , $children );
$cat_qpart = " cat_id IN ( $children ) " ;
} else {
$cat_qpart = " cat_id IS NULL " ;
}
2017-12-01 16:42:02 +00:00
$sth = $pdo -> prepare ( " UPDATE ttrss_user_entries
move the following to Feeds:
+ static function catchup_feed($feed, $cat_view, $owner_uid = false, $mode = 'all', $search = false) {
+ static function getFeedArticles($feed, $is_cat = false, $unread_only = false,
+ static function subscribe_to_feed($url, $cat_id = 0,
+ static function getFeedIcon($id) {
+ static function getFeedTitle($id, $cat = false) {
+ static function getCategoryUnread($cat, $owner_uid = false) {
+ static function getCategoryChildrenUnread($cat, $owner_uid = false) {
2017-05-04 11:50:56 +00:00
SET unread = false , last_read = NOW () WHERE ref_id IN
( SELECT id FROM
( SELECT DISTINCT id FROM ttrss_entries , ttrss_user_entries WHERE ref_id = id
2017-12-01 16:42:02 +00:00
AND owner_uid = ? AND unread = true AND feed_id IN
move the following to Feeds:
+ static function catchup_feed($feed, $cat_view, $owner_uid = false, $mode = 'all', $search = false) {
+ static function getFeedArticles($feed, $is_cat = false, $unread_only = false,
+ static function subscribe_to_feed($url, $cat_id = 0,
+ static function getFeedIcon($id) {
+ static function getFeedTitle($id, $cat = false) {
+ static function getCategoryUnread($cat, $owner_uid = false) {
+ static function getCategoryChildrenUnread($cat, $owner_uid = false) {
2017-05-04 11:50:56 +00:00
( SELECT id FROM ttrss_feeds WHERE $cat_qpart ) AND $date_qpart AND $search_qpart ) as tmp ) " );
2017-12-01 16:42:02 +00:00
$sth -> execute ([ $owner_uid ]);
move the following to Feeds:
+ static function catchup_feed($feed, $cat_view, $owner_uid = false, $mode = 'all', $search = false) {
+ static function getFeedArticles($feed, $is_cat = false, $unread_only = false,
+ static function subscribe_to_feed($url, $cat_id = 0,
+ static function getFeedIcon($id) {
+ static function getFeedTitle($id, $cat = false) {
+ static function getCategoryUnread($cat, $owner_uid = false) {
+ static function getCategoryChildrenUnread($cat, $owner_uid = false) {
2017-05-04 11:50:56 +00:00
} else if ( $feed == - 2 ) {
2017-12-01 16:42:02 +00:00
$sth = $pdo -> prepare ( " UPDATE ttrss_user_entries
move the following to Feeds:
+ static function catchup_feed($feed, $cat_view, $owner_uid = false, $mode = 'all', $search = false) {
+ static function getFeedArticles($feed, $is_cat = false, $unread_only = false,
+ static function subscribe_to_feed($url, $cat_id = 0,
+ static function getFeedIcon($id) {
+ static function getFeedTitle($id, $cat = false) {
+ static function getCategoryUnread($cat, $owner_uid = false) {
+ static function getCategoryChildrenUnread($cat, $owner_uid = false) {
2017-05-04 11:50:56 +00:00
SET unread = false , last_read = NOW () WHERE ( SELECT COUNT ( * )
FROM ttrss_user_labels2 , ttrss_entries WHERE article_id = ref_id AND id = ref_id AND $date_qpart AND $search_qpart ) > 0
2017-12-01 16:42:02 +00:00
AND unread = true AND owner_uid = ? " );
$sth -> execute ([ $owner_uid ]);
move the following to Feeds:
+ static function catchup_feed($feed, $cat_view, $owner_uid = false, $mode = 'all', $search = false) {
+ static function getFeedArticles($feed, $is_cat = false, $unread_only = false,
+ static function subscribe_to_feed($url, $cat_id = 0,
+ static function getFeedIcon($id) {
+ static function getFeedTitle($id, $cat = false) {
+ static function getCategoryUnread($cat, $owner_uid = false) {
+ static function getCategoryChildrenUnread($cat, $owner_uid = false) {
2017-05-04 11:50:56 +00:00
}
} else if ( $feed > 0 ) {
2017-12-01 16:42:02 +00:00
$sth = $pdo -> prepare ( " UPDATE ttrss_user_entries
move the following to Feeds:
+ static function catchup_feed($feed, $cat_view, $owner_uid = false, $mode = 'all', $search = false) {
+ static function getFeedArticles($feed, $is_cat = false, $unread_only = false,
+ static function subscribe_to_feed($url, $cat_id = 0,
+ static function getFeedIcon($id) {
+ static function getFeedTitle($id, $cat = false) {
+ static function getCategoryUnread($cat, $owner_uid = false) {
+ static function getCategoryChildrenUnread($cat, $owner_uid = false) {
2017-05-04 11:50:56 +00:00
SET unread = false , last_read = NOW () WHERE ref_id IN
( SELECT id FROM
( SELECT DISTINCT id FROM ttrss_entries , ttrss_user_entries WHERE ref_id = id
2017-12-01 16:42:02 +00:00
AND owner_uid = ? AND unread = true AND feed_id = ? AND $date_qpart AND $search_qpart ) as tmp ) " );
$sth -> execute ([ $owner_uid , $feed ]);
move the following to Feeds:
+ static function catchup_feed($feed, $cat_view, $owner_uid = false, $mode = 'all', $search = false) {
+ static function getFeedArticles($feed, $is_cat = false, $unread_only = false,
+ static function subscribe_to_feed($url, $cat_id = 0,
+ static function getFeedIcon($id) {
+ static function getFeedTitle($id, $cat = false) {
+ static function getCategoryUnread($cat, $owner_uid = false) {
+ static function getCategoryChildrenUnread($cat, $owner_uid = false) {
2017-05-04 11:50:56 +00:00
} else if ( $feed < 0 && $feed > LABEL_BASE_INDEX ) { // special, like starred
if ( $feed == - 1 ) {
2017-12-01 16:42:02 +00:00
$sth = $pdo -> prepare ( " UPDATE ttrss_user_entries
move the following to Feeds:
+ static function catchup_feed($feed, $cat_view, $owner_uid = false, $mode = 'all', $search = false) {
+ static function getFeedArticles($feed, $is_cat = false, $unread_only = false,
+ static function subscribe_to_feed($url, $cat_id = 0,
+ static function getFeedIcon($id) {
+ static function getFeedTitle($id, $cat = false) {
+ static function getCategoryUnread($cat, $owner_uid = false) {
+ static function getCategoryChildrenUnread($cat, $owner_uid = false) {
2017-05-04 11:50:56 +00:00
SET unread = false , last_read = NOW () WHERE ref_id IN
( SELECT id FROM
( SELECT DISTINCT id FROM ttrss_entries , ttrss_user_entries WHERE ref_id = id
2017-12-01 16:42:02 +00:00
AND owner_uid = ? AND unread = true AND marked = true AND $date_qpart AND $search_qpart ) as tmp ) " );
$sth -> execute ([ $owner_uid ]);
move the following to Feeds:
+ static function catchup_feed($feed, $cat_view, $owner_uid = false, $mode = 'all', $search = false) {
+ static function getFeedArticles($feed, $is_cat = false, $unread_only = false,
+ static function subscribe_to_feed($url, $cat_id = 0,
+ static function getFeedIcon($id) {
+ static function getFeedTitle($id, $cat = false) {
+ static function getCategoryUnread($cat, $owner_uid = false) {
+ static function getCategoryChildrenUnread($cat, $owner_uid = false) {
2017-05-04 11:50:56 +00:00
}
if ( $feed == - 2 ) {
2017-12-01 16:42:02 +00:00
$sth = $pdo -> prepare ( " UPDATE ttrss_user_entries
move the following to Feeds:
+ static function catchup_feed($feed, $cat_view, $owner_uid = false, $mode = 'all', $search = false) {
+ static function getFeedArticles($feed, $is_cat = false, $unread_only = false,
+ static function subscribe_to_feed($url, $cat_id = 0,
+ static function getFeedIcon($id) {
+ static function getFeedTitle($id, $cat = false) {
+ static function getCategoryUnread($cat, $owner_uid = false) {
+ static function getCategoryChildrenUnread($cat, $owner_uid = false) {
2017-05-04 11:50:56 +00:00
SET unread = false , last_read = NOW () WHERE ref_id IN
( SELECT id FROM
( SELECT DISTINCT id FROM ttrss_entries , ttrss_user_entries WHERE ref_id = id
2017-12-01 16:42:02 +00:00
AND owner_uid = ? AND unread = true AND published = true AND $date_qpart AND $search_qpart ) as tmp ) " );
$sth -> execute ([ $owner_uid ]);
move the following to Feeds:
+ static function catchup_feed($feed, $cat_view, $owner_uid = false, $mode = 'all', $search = false) {
+ static function getFeedArticles($feed, $is_cat = false, $unread_only = false,
+ static function subscribe_to_feed($url, $cat_id = 0,
+ static function getFeedIcon($id) {
+ static function getFeedTitle($id, $cat = false) {
+ static function getCategoryUnread($cat, $owner_uid = false) {
+ static function getCategoryChildrenUnread($cat, $owner_uid = false) {
2017-05-04 11:50:56 +00:00
}
if ( $feed == - 3 ) {
2017-12-01 16:42:02 +00:00
$intl = ( int ) get_pref ( " FRESH_ARTICLE_MAX_AGE " );
move the following to Feeds:
+ static function catchup_feed($feed, $cat_view, $owner_uid = false, $mode = 'all', $search = false) {
+ static function getFeedArticles($feed, $is_cat = false, $unread_only = false,
+ static function subscribe_to_feed($url, $cat_id = 0,
+ static function getFeedIcon($id) {
+ static function getFeedTitle($id, $cat = false) {
+ static function getCategoryUnread($cat, $owner_uid = false) {
+ static function getCategoryChildrenUnread($cat, $owner_uid = false) {
2017-05-04 11:50:56 +00:00
if ( DB_TYPE == " pgsql " ) {
$match_part = " date_entered > NOW() - INTERVAL ' $intl hour' " ;
} else {
$match_part = " date_entered > DATE_SUB(NOW(),
INTERVAL $intl HOUR ) " ;
}
2017-12-01 16:42:02 +00:00
$sth = $pdo -> prepare ( " UPDATE ttrss_user_entries
move the following to Feeds:
+ static function catchup_feed($feed, $cat_view, $owner_uid = false, $mode = 'all', $search = false) {
+ static function getFeedArticles($feed, $is_cat = false, $unread_only = false,
+ static function subscribe_to_feed($url, $cat_id = 0,
+ static function getFeedIcon($id) {
+ static function getFeedTitle($id, $cat = false) {
+ static function getCategoryUnread($cat, $owner_uid = false) {
+ static function getCategoryChildrenUnread($cat, $owner_uid = false) {
2017-05-04 11:50:56 +00:00
SET unread = false , last_read = NOW () WHERE ref_id IN
( SELECT id FROM
( SELECT DISTINCT id FROM ttrss_entries , ttrss_user_entries WHERE ref_id = id
2017-12-01 16:42:02 +00:00
AND owner_uid = ? AND score >= 0 AND unread = true AND $date_qpart AND $match_part AND $search_qpart ) as tmp ) " );
$sth -> execute ([ $owner_uid ]);
move the following to Feeds:
+ static function catchup_feed($feed, $cat_view, $owner_uid = false, $mode = 'all', $search = false) {
+ static function getFeedArticles($feed, $is_cat = false, $unread_only = false,
+ static function subscribe_to_feed($url, $cat_id = 0,
+ static function getFeedIcon($id) {
+ static function getFeedTitle($id, $cat = false) {
+ static function getCategoryUnread($cat, $owner_uid = false) {
+ static function getCategoryChildrenUnread($cat, $owner_uid = false) {
2017-05-04 11:50:56 +00:00
}
if ( $feed == - 4 ) {
2017-12-01 16:42:02 +00:00
$sth = $pdo -> prepare ( " UPDATE ttrss_user_entries
move the following to Feeds:
+ static function catchup_feed($feed, $cat_view, $owner_uid = false, $mode = 'all', $search = false) {
+ static function getFeedArticles($feed, $is_cat = false, $unread_only = false,
+ static function subscribe_to_feed($url, $cat_id = 0,
+ static function getFeedIcon($id) {
+ static function getFeedTitle($id, $cat = false) {
+ static function getCategoryUnread($cat, $owner_uid = false) {
+ static function getCategoryChildrenUnread($cat, $owner_uid = false) {
2017-05-04 11:50:56 +00:00
SET unread = false , last_read = NOW () WHERE ref_id IN
( SELECT id FROM
( SELECT DISTINCT id FROM ttrss_entries , ttrss_user_entries WHERE ref_id = id
2017-12-01 16:42:02 +00:00
AND owner_uid = ? AND unread = true AND $date_qpart AND $search_qpart ) as tmp ) " );
$sth -> execute ([ $owner_uid ]);
move the following to Feeds:
+ static function catchup_feed($feed, $cat_view, $owner_uid = false, $mode = 'all', $search = false) {
+ static function getFeedArticles($feed, $is_cat = false, $unread_only = false,
+ static function subscribe_to_feed($url, $cat_id = 0,
+ static function getFeedIcon($id) {
+ static function getFeedTitle($id, $cat = false) {
+ static function getCategoryUnread($cat, $owner_uid = false) {
+ static function getCategoryChildrenUnread($cat, $owner_uid = false) {
2017-05-04 11:50:56 +00:00
}
} else if ( $feed < LABEL_BASE_INDEX ) { // label
2017-05-04 12:57:40 +00:00
$label_id = Labels :: feed_to_label_id ( $feed );
move the following to Feeds:
+ static function catchup_feed($feed, $cat_view, $owner_uid = false, $mode = 'all', $search = false) {
+ static function getFeedArticles($feed, $is_cat = false, $unread_only = false,
+ static function subscribe_to_feed($url, $cat_id = 0,
+ static function getFeedIcon($id) {
+ static function getFeedTitle($id, $cat = false) {
+ static function getCategoryUnread($cat, $owner_uid = false) {
+ static function getCategoryChildrenUnread($cat, $owner_uid = false) {
2017-05-04 11:50:56 +00:00
2017-12-01 16:42:02 +00:00
$sth = $pdo -> prepare ( " UPDATE ttrss_user_entries
move the following to Feeds:
+ static function catchup_feed($feed, $cat_view, $owner_uid = false, $mode = 'all', $search = false) {
+ static function getFeedArticles($feed, $is_cat = false, $unread_only = false,
+ static function subscribe_to_feed($url, $cat_id = 0,
+ static function getFeedIcon($id) {
+ static function getFeedTitle($id, $cat = false) {
+ static function getCategoryUnread($cat, $owner_uid = false) {
+ static function getCategoryChildrenUnread($cat, $owner_uid = false) {
2017-05-04 11:50:56 +00:00
SET unread = false , last_read = NOW () WHERE ref_id IN
( SELECT id FROM
( SELECT DISTINCT ttrss_entries . id FROM ttrss_entries , ttrss_user_entries , ttrss_user_labels2 WHERE ref_id = id
2017-12-01 16:42:02 +00:00
AND label_id = ? AND ref_id = article_id
AND owner_uid = ? AND unread = true AND $date_qpart AND $search_qpart ) as tmp ) " );
$sth -> execute ([ $label_id , $owner_uid ]);
move the following to Feeds:
+ static function catchup_feed($feed, $cat_view, $owner_uid = false, $mode = 'all', $search = false) {
+ static function getFeedArticles($feed, $is_cat = false, $unread_only = false,
+ static function subscribe_to_feed($url, $cat_id = 0,
+ static function getFeedIcon($id) {
+ static function getFeedTitle($id, $cat = false) {
+ static function getCategoryUnread($cat, $owner_uid = false) {
+ static function getCategoryChildrenUnread($cat, $owner_uid = false) {
2017-05-04 11:50:56 +00:00
}
2017-05-04 12:22:57 +00:00
CCache :: update ( $feed , $owner_uid , $cat_view );
move the following to Feeds:
+ static function catchup_feed($feed, $cat_view, $owner_uid = false, $mode = 'all', $search = false) {
+ static function getFeedArticles($feed, $is_cat = false, $unread_only = false,
+ static function subscribe_to_feed($url, $cat_id = 0,
+ static function getFeedIcon($id) {
+ static function getFeedTitle($id, $cat = false) {
+ static function getCategoryUnread($cat, $owner_uid = false) {
+ static function getCategoryChildrenUnread($cat, $owner_uid = false) {
2017-05-04 11:50:56 +00:00
} else { // tag
2017-12-01 16:42:02 +00:00
$sth = $pdo -> prepare ( " UPDATE ttrss_user_entries
move the following to Feeds:
+ static function catchup_feed($feed, $cat_view, $owner_uid = false, $mode = 'all', $search = false) {
+ static function getFeedArticles($feed, $is_cat = false, $unread_only = false,
+ static function subscribe_to_feed($url, $cat_id = 0,
+ static function getFeedIcon($id) {
+ static function getFeedTitle($id, $cat = false) {
+ static function getCategoryUnread($cat, $owner_uid = false) {
+ static function getCategoryChildrenUnread($cat, $owner_uid = false) {
2017-05-04 11:50:56 +00:00
SET unread = false , last_read = NOW () WHERE ref_id IN
( SELECT id FROM
( SELECT DISTINCT ttrss_entries . id FROM ttrss_entries , ttrss_user_entries , ttrss_tags WHERE ref_id = ttrss_entries . id
2017-12-01 16:42:02 +00:00
AND post_int_id = int_id AND tag_name = ?
AND ttrss_user_entries . owner_uid = ? AND unread = true AND $date_qpart AND $search_qpart ) as tmp ) " );
$sth -> execute ([ $feed , $owner_uid ]);
move the following to Feeds:
+ static function catchup_feed($feed, $cat_view, $owner_uid = false, $mode = 'all', $search = false) {
+ static function getFeedArticles($feed, $is_cat = false, $unread_only = false,
+ static function subscribe_to_feed($url, $cat_id = 0,
+ static function getFeedIcon($id) {
+ static function getFeedTitle($id, $cat = false) {
+ static function getCategoryUnread($cat, $owner_uid = false) {
+ static function getCategoryChildrenUnread($cat, $owner_uid = false) {
2017-05-04 11:50:56 +00:00
}
}
static function getFeedArticles ( $feed , $is_cat = false , $unread_only = false ,
$owner_uid = false ) {
$n_feed = ( int ) $feed ;
$need_entries = false ;
2017-12-01 17:15:25 +00:00
$pdo = Db :: pdo ();
move the following to Feeds:
+ static function catchup_feed($feed, $cat_view, $owner_uid = false, $mode = 'all', $search = false) {
+ static function getFeedArticles($feed, $is_cat = false, $unread_only = false,
+ static function subscribe_to_feed($url, $cat_id = 0,
+ static function getFeedIcon($id) {
+ static function getFeedTitle($id, $cat = false) {
+ static function getCategoryUnread($cat, $owner_uid = false) {
+ static function getCategoryChildrenUnread($cat, $owner_uid = false) {
2017-05-04 11:50:56 +00:00
if ( ! $owner_uid ) $owner_uid = $_SESSION [ " uid " ];
if ( $unread_only ) {
$unread_qpart = " unread = true " ;
} else {
$unread_qpart = " true " ;
}
2017-12-01 17:15:25 +00:00
$match_part = " " ;
move the following to Feeds:
+ static function catchup_feed($feed, $cat_view, $owner_uid = false, $mode = 'all', $search = false) {
+ static function getFeedArticles($feed, $is_cat = false, $unread_only = false,
+ static function subscribe_to_feed($url, $cat_id = 0,
+ static function getFeedIcon($id) {
+ static function getFeedTitle($id, $cat = false) {
+ static function getCategoryUnread($cat, $owner_uid = false) {
+ static function getCategoryChildrenUnread($cat, $owner_uid = false) {
2017-05-04 11:50:56 +00:00
if ( $is_cat ) {
return Feeds :: getCategoryUnread ( $n_feed , $owner_uid );
} else if ( $n_feed == - 6 ) {
return 0 ;
} else if ( $feed != " 0 " && $n_feed == 0 ) {
2017-12-01 17:15:25 +00:00
$sth = $pdo -> prepare ( " SELECT SUM((SELECT COUNT(int_id)
move the following to Feeds:
+ static function catchup_feed($feed, $cat_view, $owner_uid = false, $mode = 'all', $search = false) {
+ static function getFeedArticles($feed, $is_cat = false, $unread_only = false,
+ static function subscribe_to_feed($url, $cat_id = 0,
+ static function getFeedIcon($id) {
+ static function getFeedTitle($id, $cat = false) {
+ static function getCategoryUnread($cat, $owner_uid = false) {
+ static function getCategoryChildrenUnread($cat, $owner_uid = false) {
2017-05-04 11:50:56 +00:00
FROM ttrss_user_entries , ttrss_entries WHERE int_id = post_int_id
AND ref_id = id AND $unread_qpart )) AS count FROM ttrss_tags
2017-12-01 17:15:25 +00:00
WHERE owner_uid = ? AND tag_name = ? " );
$sth -> execute ([ $owner_uid , $feed ]);
$row = $sth -> fetch ();
return $row [ " count " ];
move the following to Feeds:
+ static function catchup_feed($feed, $cat_view, $owner_uid = false, $mode = 'all', $search = false) {
+ static function getFeedArticles($feed, $is_cat = false, $unread_only = false,
+ static function subscribe_to_feed($url, $cat_id = 0,
+ static function getFeedIcon($id) {
+ static function getFeedTitle($id, $cat = false) {
+ static function getCategoryUnread($cat, $owner_uid = false) {
+ static function getCategoryChildrenUnread($cat, $owner_uid = false) {
2017-05-04 11:50:56 +00:00
} else if ( $n_feed == - 1 ) {
$match_part = " marked = true " ;
} else if ( $n_feed == - 2 ) {
$match_part = " published = true " ;
} else if ( $n_feed == - 3 ) {
$match_part = " unread = true AND score >= 0 " ;
2017-12-01 17:15:25 +00:00
$intl = ( int ) get_pref ( " FRESH_ARTICLE_MAX_AGE " , $owner_uid );
move the following to Feeds:
+ static function catchup_feed($feed, $cat_view, $owner_uid = false, $mode = 'all', $search = false) {
+ static function getFeedArticles($feed, $is_cat = false, $unread_only = false,
+ static function subscribe_to_feed($url, $cat_id = 0,
+ static function getFeedIcon($id) {
+ static function getFeedTitle($id, $cat = false) {
+ static function getCategoryUnread($cat, $owner_uid = false) {
+ static function getCategoryChildrenUnread($cat, $owner_uid = false) {
2017-05-04 11:50:56 +00:00
if ( DB_TYPE == " pgsql " ) {
$match_part .= " AND date_entered > NOW() - INTERVAL ' $intl hour' " ;
} else {
$match_part .= " AND date_entered > DATE_SUB(NOW(), INTERVAL $intl HOUR) " ;
}
$need_entries = true ;
} else if ( $n_feed == - 4 ) {
$match_part = " true " ;
} else if ( $n_feed >= 0 ) {
if ( $n_feed != 0 ) {
2017-12-17 13:24:13 +00:00
$match_part = " feed_id = " . ( int ) $n_feed ;
move the following to Feeds:
+ static function catchup_feed($feed, $cat_view, $owner_uid = false, $mode = 'all', $search = false) {
+ static function getFeedArticles($feed, $is_cat = false, $unread_only = false,
+ static function subscribe_to_feed($url, $cat_id = 0,
+ static function getFeedIcon($id) {
+ static function getFeedTitle($id, $cat = false) {
+ static function getCategoryUnread($cat, $owner_uid = false) {
+ static function getCategoryChildrenUnread($cat, $owner_uid = false) {
2017-05-04 11:50:56 +00:00
} else {
$match_part = " feed_id IS NULL " ;
}
} else if ( $feed < LABEL_BASE_INDEX ) {
2017-05-04 12:57:40 +00:00
$label_id = Labels :: feed_to_label_id ( $feed );
move the following to Feeds:
+ static function catchup_feed($feed, $cat_view, $owner_uid = false, $mode = 'all', $search = false) {
+ static function getFeedArticles($feed, $is_cat = false, $unread_only = false,
+ static function subscribe_to_feed($url, $cat_id = 0,
+ static function getFeedIcon($id) {
+ static function getFeedTitle($id, $cat = false) {
+ static function getCategoryUnread($cat, $owner_uid = false) {
+ static function getCategoryChildrenUnread($cat, $owner_uid = false) {
2017-05-04 11:50:56 +00:00
2017-05-04 12:00:21 +00:00
return Feeds :: getLabelUnread ( $label_id , $owner_uid );
move the following to Feeds:
+ static function catchup_feed($feed, $cat_view, $owner_uid = false, $mode = 'all', $search = false) {
+ static function getFeedArticles($feed, $is_cat = false, $unread_only = false,
+ static function subscribe_to_feed($url, $cat_id = 0,
+ static function getFeedIcon($id) {
+ static function getFeedTitle($id, $cat = false) {
+ static function getCategoryUnread($cat, $owner_uid = false) {
+ static function getCategoryChildrenUnread($cat, $owner_uid = false) {
2017-05-04 11:50:56 +00:00
}
if ( $match_part ) {
if ( $need_entries ) {
$from_qpart = " ttrss_user_entries,ttrss_entries " ;
$from_where = " ttrss_entries.id = ttrss_user_entries.ref_id AND " ;
} else {
$from_qpart = " ttrss_user_entries " ;
$from_where = " " ;
}
2017-12-01 17:15:25 +00:00
$sth = $pdo -> prepare ( " SELECT count(int_id) AS unread
move the following to Feeds:
+ static function catchup_feed($feed, $cat_view, $owner_uid = false, $mode = 'all', $search = false) {
+ static function getFeedArticles($feed, $is_cat = false, $unread_only = false,
+ static function subscribe_to_feed($url, $cat_id = 0,
+ static function getFeedIcon($id) {
+ static function getFeedTitle($id, $cat = false) {
+ static function getCategoryUnread($cat, $owner_uid = false) {
+ static function getCategoryChildrenUnread($cat, $owner_uid = false) {
2017-05-04 11:50:56 +00:00
FROM $from_qpart WHERE
2017-12-01 17:15:25 +00:00
$unread_qpart AND $from_where ( $match_part ) AND ttrss_user_entries . owner_uid = ? " );
$sth -> execute ([ $owner_uid ]);
$row = $sth -> fetch ();
move the following to Feeds:
+ static function catchup_feed($feed, $cat_view, $owner_uid = false, $mode = 'all', $search = false) {
+ static function getFeedArticles($feed, $is_cat = false, $unread_only = false,
+ static function subscribe_to_feed($url, $cat_id = 0,
+ static function getFeedIcon($id) {
+ static function getFeedTitle($id, $cat = false) {
+ static function getCategoryUnread($cat, $owner_uid = false) {
+ static function getCategoryChildrenUnread($cat, $owner_uid = false) {
2017-05-04 11:50:56 +00:00
2017-12-01 17:15:25 +00:00
return $row [ " unread " ];
move the following to Feeds:
+ static function catchup_feed($feed, $cat_view, $owner_uid = false, $mode = 'all', $search = false) {
+ static function getFeedArticles($feed, $is_cat = false, $unread_only = false,
+ static function subscribe_to_feed($url, $cat_id = 0,
+ static function getFeedIcon($id) {
+ static function getFeedTitle($id, $cat = false) {
+ static function getCategoryUnread($cat, $owner_uid = false) {
+ static function getCategoryChildrenUnread($cat, $owner_uid = false) {
2017-05-04 11:50:56 +00:00
} else {
2017-12-01 17:15:25 +00:00
$sth = $pdo -> prepare ( " SELECT COUNT(post_int_id) AS unread
move the following to Feeds:
+ static function catchup_feed($feed, $cat_view, $owner_uid = false, $mode = 'all', $search = false) {
+ static function getFeedArticles($feed, $is_cat = false, $unread_only = false,
+ static function subscribe_to_feed($url, $cat_id = 0,
+ static function getFeedIcon($id) {
+ static function getFeedTitle($id, $cat = false) {
+ static function getCategoryUnread($cat, $owner_uid = false) {
+ static function getCategoryChildrenUnread($cat, $owner_uid = false) {
2017-05-04 11:50:56 +00:00
FROM ttrss_tags , ttrss_user_entries , ttrss_entries
2017-12-01 17:15:25 +00:00
WHERE tag_name = ? AND post_int_id = int_id AND ref_id = ttrss_entries . id
AND $unread_qpart AND ttrss_tags . owner_uid = , " );
move the following to Feeds:
+ static function catchup_feed($feed, $cat_view, $owner_uid = false, $mode = 'all', $search = false) {
+ static function getFeedArticles($feed, $is_cat = false, $unread_only = false,
+ static function subscribe_to_feed($url, $cat_id = 0,
+ static function getFeedIcon($id) {
+ static function getFeedTitle($id, $cat = false) {
+ static function getCategoryUnread($cat, $owner_uid = false) {
+ static function getCategoryChildrenUnread($cat, $owner_uid = false) {
2017-05-04 11:50:56 +00:00
2017-12-01 17:15:25 +00:00
$sth -> execute ([ $feed , $owner_uid ]);
$row = $sth -> fetch ();
move the following to Feeds:
+ static function catchup_feed($feed, $cat_view, $owner_uid = false, $mode = 'all', $search = false) {
+ static function getFeedArticles($feed, $is_cat = false, $unread_only = false,
+ static function subscribe_to_feed($url, $cat_id = 0,
+ static function getFeedIcon($id) {
+ static function getFeedTitle($id, $cat = false) {
+ static function getCategoryUnread($cat, $owner_uid = false) {
+ static function getCategoryChildrenUnread($cat, $owner_uid = false) {
2017-05-04 11:50:56 +00:00
2017-12-01 17:15:25 +00:00
return $row [ " unread " ];
}
move the following to Feeds:
+ static function catchup_feed($feed, $cat_view, $owner_uid = false, $mode = 'all', $search = false) {
+ static function getFeedArticles($feed, $is_cat = false, $unread_only = false,
+ static function subscribe_to_feed($url, $cat_id = 0,
+ static function getFeedIcon($id) {
+ static function getFeedTitle($id, $cat = false) {
+ static function getCategoryUnread($cat, $owner_uid = false) {
+ static function getCategoryChildrenUnread($cat, $owner_uid = false) {
2017-05-04 11:50:56 +00:00
}
/**
* @ return array ( code => Status code , message => error message if available )
*
* 0 - OK , Feed already exists
* 1 - OK , Feed added
* 2 - Invalid URL
* 3 - URL content is HTML , no feeds available
* 4 - URL content is HTML which contains multiple feeds .
* Here you should call extractfeedurls in rpc - backend
* to get all possible feeds .
* 5 - Couldn ' t download the URL content .
* 6 - Content is an invalid XML .
*/
static function subscribe_to_feed ( $url , $cat_id = 0 ,
$auth_login = '' , $auth_pass = '' ) {
global $fetch_last_error ;
global $fetch_last_error_content ;
2017-12-01 17:15:25 +00:00
$pdo = Db :: pdo ();
move the following to Feeds:
+ static function catchup_feed($feed, $cat_view, $owner_uid = false, $mode = 'all', $search = false) {
+ static function getFeedArticles($feed, $is_cat = false, $unread_only = false,
+ static function subscribe_to_feed($url, $cat_id = 0,
+ static function getFeedIcon($id) {
+ static function getFeedTitle($id, $cat = false) {
+ static function getCategoryUnread($cat, $owner_uid = false) {
+ static function getCategoryChildrenUnread($cat, $owner_uid = false) {
2017-05-04 11:50:56 +00:00
$url = fix_url ( $url );
if ( ! $url || ! validate_feed_url ( $url )) return array ( " code " => 2 );
$contents = @ fetch_file_contents ( $url , false , $auth_login , $auth_pass );
2018-05-23 09:00:04 +00:00
foreach ( PluginHost :: getInstance () -> get_hooks ( PluginHost :: HOOK_SUBSCRIBE_FEED ) as $plugin ) {
$contents = $plugin -> hook_subscribe_feed ( $contents , $url , $auth_login , $auth_pass );
}
2018-11-03 12:08:43 +00:00
move the following to Feeds:
+ static function catchup_feed($feed, $cat_view, $owner_uid = false, $mode = 'all', $search = false) {
+ static function getFeedArticles($feed, $is_cat = false, $unread_only = false,
+ static function subscribe_to_feed($url, $cat_id = 0,
+ static function getFeedIcon($id) {
+ static function getFeedTitle($id, $cat = false) {
+ static function getCategoryUnread($cat, $owner_uid = false) {
+ static function getCategoryChildrenUnread($cat, $owner_uid = false) {
2017-05-04 11:50:56 +00:00
if ( ! $contents ) {
if ( preg_match ( " /cloudflare \ .com/ " , $fetch_last_error_content )) {
$fetch_last_error .= " (feed behind Cloudflare) " ;
}
return array ( " code " => 5 , " message " => $fetch_last_error );
}
if ( is_html ( $contents )) {
$feedUrls = get_feeds_from_html ( $url , $contents );
if ( count ( $feedUrls ) == 0 ) {
return array ( " code " => 3 );
} else if ( count ( $feedUrls ) > 1 ) {
return array ( " code " => 4 , " feeds " => $feedUrls );
}
//use feed url as new URL
$url = key ( $feedUrls );
}
2017-12-03 20:08:04 +00:00
if ( ! $cat_id ) $cat_id = null ;
move the following to Feeds:
+ static function catchup_feed($feed, $cat_view, $owner_uid = false, $mode = 'all', $search = false) {
+ static function getFeedArticles($feed, $is_cat = false, $unread_only = false,
+ static function subscribe_to_feed($url, $cat_id = 0,
+ static function getFeedIcon($id) {
+ static function getFeedTitle($id, $cat = false) {
+ static function getCategoryUnread($cat, $owner_uid = false) {
+ static function getCategoryChildrenUnread($cat, $owner_uid = false) {
2017-05-04 11:50:56 +00:00
2017-12-01 17:15:25 +00:00
$sth = $pdo -> prepare ( " SELECT id FROM ttrss_feeds
WHERE feed_url = ? AND owner_uid = ? " );
$sth -> execute ([ $url , $_SESSION [ 'uid' ]]);
move the following to Feeds:
+ static function catchup_feed($feed, $cat_view, $owner_uid = false, $mode = 'all', $search = false) {
+ static function getFeedArticles($feed, $is_cat = false, $unread_only = false,
+ static function subscribe_to_feed($url, $cat_id = 0,
+ static function getFeedIcon($id) {
+ static function getFeedTitle($id, $cat = false) {
+ static function getCategoryUnread($cat, $owner_uid = false) {
+ static function getCategoryChildrenUnread($cat, $owner_uid = false) {
2017-05-04 11:50:56 +00:00
2017-12-01 17:15:25 +00:00
if ( $row = $sth -> fetch ()) {
return array ( " code " => 0 , " feed_id " => ( int ) $row [ " id " ]);
} else {
$sth = $pdo -> prepare (
move the following to Feeds:
+ static function catchup_feed($feed, $cat_view, $owner_uid = false, $mode = 'all', $search = false) {
+ static function getFeedArticles($feed, $is_cat = false, $unread_only = false,
+ static function subscribe_to_feed($url, $cat_id = 0,
+ static function getFeedIcon($id) {
+ static function getFeedTitle($id, $cat = false) {
+ static function getCategoryUnread($cat, $owner_uid = false) {
+ static function getCategoryChildrenUnread($cat, $owner_uid = false) {
2017-05-04 11:50:56 +00:00
" INSERT INTO ttrss_feeds
( owner_uid , feed_url , title , cat_id , auth_login , auth_pass , update_method , auth_pass_encrypted )
2017-12-01 17:15:25 +00:00
VALUES ( ? , ? , ? , ? , ? , ? , 0 , false ) " );
move the following to Feeds:
+ static function catchup_feed($feed, $cat_view, $owner_uid = false, $mode = 'all', $search = false) {
+ static function getFeedArticles($feed, $is_cat = false, $unread_only = false,
+ static function subscribe_to_feed($url, $cat_id = 0,
+ static function getFeedIcon($id) {
+ static function getFeedTitle($id, $cat = false) {
+ static function getCategoryUnread($cat, $owner_uid = false) {
+ static function getCategoryChildrenUnread($cat, $owner_uid = false) {
2017-05-04 11:50:56 +00:00
2018-01-05 03:50:37 +00:00
$sth -> execute ([ $_SESSION [ 'uid' ], $url , " [Unknown] " , $cat_id , ( string ) $auth_login , ( string ) $auth_pass ]);
move the following to Feeds:
+ static function catchup_feed($feed, $cat_view, $owner_uid = false, $mode = 'all', $search = false) {
+ static function getFeedArticles($feed, $is_cat = false, $unread_only = false,
+ static function subscribe_to_feed($url, $cat_id = 0,
+ static function getFeedIcon($id) {
+ static function getFeedTitle($id, $cat = false) {
+ static function getCategoryUnread($cat, $owner_uid = false) {
+ static function getCategoryChildrenUnread($cat, $owner_uid = false) {
2017-05-04 11:50:56 +00:00
2017-12-01 17:15:25 +00:00
$sth = $pdo -> prepare ( " SELECT id FROM ttrss_feeds WHERE feed_url = ?
AND owner_uid = ? " );
$sth -> execute ([ $url , $_SESSION [ 'uid' ]]);
$row = $sth -> fetch ();
$feed_id = $row [ " id " ];
move the following to Feeds:
+ static function catchup_feed($feed, $cat_view, $owner_uid = false, $mode = 'all', $search = false) {
+ static function getFeedArticles($feed, $is_cat = false, $unread_only = false,
+ static function subscribe_to_feed($url, $cat_id = 0,
+ static function getFeedIcon($id) {
+ static function getFeedTitle($id, $cat = false) {
+ static function getCategoryUnread($cat, $owner_uid = false) {
+ static function getCategoryChildrenUnread($cat, $owner_uid = false) {
2017-05-04 11:50:56 +00:00
if ( $feed_id ) {
2017-05-05 15:10:07 +00:00
RSSUtils :: set_basic_feed_info ( $feed_id );
move the following to Feeds:
+ static function catchup_feed($feed, $cat_view, $owner_uid = false, $mode = 'all', $search = false) {
+ static function getFeedArticles($feed, $is_cat = false, $unread_only = false,
+ static function subscribe_to_feed($url, $cat_id = 0,
+ static function getFeedIcon($id) {
+ static function getFeedTitle($id, $cat = false) {
+ static function getCategoryUnread($cat, $owner_uid = false) {
+ static function getCategoryChildrenUnread($cat, $owner_uid = false) {
2017-05-04 11:50:56 +00:00
}
return array ( " code " => 1 , " feed_id " => ( int ) $feed_id );
2017-12-01 17:15:25 +00:00
move the following to Feeds:
+ static function catchup_feed($feed, $cat_view, $owner_uid = false, $mode = 'all', $search = false) {
+ static function getFeedArticles($feed, $is_cat = false, $unread_only = false,
+ static function subscribe_to_feed($url, $cat_id = 0,
+ static function getFeedIcon($id) {
+ static function getFeedTitle($id, $cat = false) {
+ static function getCategoryUnread($cat, $owner_uid = false) {
+ static function getCategoryChildrenUnread($cat, $owner_uid = false) {
2017-05-04 11:50:56 +00:00
}
}
2017-12-03 19:35:12 +00:00
static function getIconFile ( $feed_id ) {
return ICONS_DIR . " / $feed_id .ico " ;
}
2017-12-03 19:49:57 +00:00
static function feedHasIcon ( $id ) {
return is_file ( ICONS_DIR . " / $id .ico " ) && filesize ( ICONS_DIR . " / $id .ico " ) > 0 ;
}
move the following to Feeds:
+ static function catchup_feed($feed, $cat_view, $owner_uid = false, $mode = 'all', $search = false) {
+ static function getFeedArticles($feed, $is_cat = false, $unread_only = false,
+ static function subscribe_to_feed($url, $cat_id = 0,
+ static function getFeedIcon($id) {
+ static function getFeedTitle($id, $cat = false) {
+ static function getCategoryUnread($cat, $owner_uid = false) {
+ static function getCategoryChildrenUnread($cat, $owner_uid = false) {
2017-05-04 11:50:56 +00:00
static function getFeedIcon ( $id ) {
switch ( $id ) {
case 0 :
return " images/archive.png " ;
break ;
case - 1 :
return " images/star.png " ;
break ;
case - 2 :
return " images/feed.png " ;
break ;
case - 3 :
return " images/fresh.png " ;
break ;
case - 4 :
return " images/folder.png " ;
break ;
case - 6 :
return " images/time.png " ;
break ;
default :
if ( $id < LABEL_BASE_INDEX ) {
return " images/label.png " ;
} else {
2017-12-03 19:35:12 +00:00
$icon = self :: getIconFile ( $id );
if ( $icon && file_exists ( $icon )) {
return ICONS_URL . " / " . basename ( $icon ) . " ? " . filemtime ( $icon );
}
move the following to Feeds:
+ static function catchup_feed($feed, $cat_view, $owner_uid = false, $mode = 'all', $search = false) {
+ static function getFeedArticles($feed, $is_cat = false, $unread_only = false,
+ static function subscribe_to_feed($url, $cat_id = 0,
+ static function getFeedIcon($id) {
+ static function getFeedTitle($id, $cat = false) {
+ static function getCategoryUnread($cat, $owner_uid = false) {
+ static function getCategoryChildrenUnread($cat, $owner_uid = false) {
2017-05-04 11:50:56 +00:00
}
break ;
}
return false ;
}
static function getFeedTitle ( $id , $cat = false ) {
2017-12-01 16:42:02 +00:00
$pdo = Db :: pdo ();
move the following to Feeds:
+ static function catchup_feed($feed, $cat_view, $owner_uid = false, $mode = 'all', $search = false) {
+ static function getFeedArticles($feed, $is_cat = false, $unread_only = false,
+ static function subscribe_to_feed($url, $cat_id = 0,
+ static function getFeedIcon($id) {
+ static function getFeedTitle($id, $cat = false) {
+ static function getCategoryUnread($cat, $owner_uid = false) {
+ static function getCategoryChildrenUnread($cat, $owner_uid = false) {
2017-05-04 11:50:56 +00:00
if ( $cat ) {
2017-05-04 12:00:21 +00:00
return Feeds :: getCategoryTitle ( $id );
move the following to Feeds:
+ static function catchup_feed($feed, $cat_view, $owner_uid = false, $mode = 'all', $search = false) {
+ static function getFeedArticles($feed, $is_cat = false, $unread_only = false,
+ static function subscribe_to_feed($url, $cat_id = 0,
+ static function getFeedIcon($id) {
+ static function getFeedTitle($id, $cat = false) {
+ static function getCategoryUnread($cat, $owner_uid = false) {
+ static function getCategoryChildrenUnread($cat, $owner_uid = false) {
2017-05-04 11:50:56 +00:00
} else if ( $id == - 1 ) {
return __ ( " Starred articles " );
} else if ( $id == - 2 ) {
return __ ( " Published articles " );
} else if ( $id == - 3 ) {
return __ ( " Fresh articles " );
} else if ( $id == - 4 ) {
return __ ( " All articles " );
} else if ( $id === 0 || $id === " 0 " ) {
return __ ( " Archived articles " );
} else if ( $id == - 6 ) {
return __ ( " Recently read " );
} else if ( $id < LABEL_BASE_INDEX ) {
2017-12-01 16:42:02 +00:00
2017-05-04 12:57:40 +00:00
$label_id = Labels :: feed_to_label_id ( $id );
2017-12-01 16:42:02 +00:00
$sth = $pdo -> prepare ( " SELECT caption FROM ttrss_labels2 WHERE id = ? " );
$sth -> execute ([ $label_id ]);
if ( $row = $sth -> fetch ()) {
return $row [ " caption " ];
move the following to Feeds:
+ static function catchup_feed($feed, $cat_view, $owner_uid = false, $mode = 'all', $search = false) {
+ static function getFeedArticles($feed, $is_cat = false, $unread_only = false,
+ static function subscribe_to_feed($url, $cat_id = 0,
+ static function getFeedIcon($id) {
+ static function getFeedTitle($id, $cat = false) {
+ static function getCategoryUnread($cat, $owner_uid = false) {
+ static function getCategoryChildrenUnread($cat, $owner_uid = false) {
2017-05-04 11:50:56 +00:00
} else {
return " Unknown label ( $label_id ) " ;
}
} else if ( is_numeric ( $id ) && $id > 0 ) {
2017-12-01 16:42:02 +00:00
$sth = $pdo -> prepare ( " SELECT title FROM ttrss_feeds WHERE id = ? " );
$sth -> execute ([ $id ]);
if ( $row = $sth -> fetch ()) {
return $row [ " title " ];
move the following to Feeds:
+ static function catchup_feed($feed, $cat_view, $owner_uid = false, $mode = 'all', $search = false) {
+ static function getFeedArticles($feed, $is_cat = false, $unread_only = false,
+ static function subscribe_to_feed($url, $cat_id = 0,
+ static function getFeedIcon($id) {
+ static function getFeedTitle($id, $cat = false) {
+ static function getCategoryUnread($cat, $owner_uid = false) {
+ static function getCategoryChildrenUnread($cat, $owner_uid = false) {
2017-05-04 11:50:56 +00:00
} else {
return " Unknown feed ( $id ) " ;
}
2017-12-01 16:42:02 +00:00
move the following to Feeds:
+ static function catchup_feed($feed, $cat_view, $owner_uid = false, $mode = 'all', $search = false) {
+ static function getFeedArticles($feed, $is_cat = false, $unread_only = false,
+ static function subscribe_to_feed($url, $cat_id = 0,
+ static function getFeedIcon($id) {
+ static function getFeedTitle($id, $cat = false) {
+ static function getCategoryUnread($cat, $owner_uid = false) {
+ static function getCategoryChildrenUnread($cat, $owner_uid = false) {
2017-05-04 11:50:56 +00:00
} else {
return $id ;
}
}
static function getCategoryUnread ( $cat , $owner_uid = false ) {
if ( ! $owner_uid ) $owner_uid = $_SESSION [ " uid " ];
2017-12-01 17:15:25 +00:00
$pdo = Db :: pdo ();
move the following to Feeds:
+ static function catchup_feed($feed, $cat_view, $owner_uid = false, $mode = 'all', $search = false) {
+ static function getFeedArticles($feed, $is_cat = false, $unread_only = false,
+ static function subscribe_to_feed($url, $cat_id = 0,
+ static function getFeedIcon($id) {
+ static function getFeedTitle($id, $cat = false) {
+ static function getCategoryUnread($cat, $owner_uid = false) {
+ static function getCategoryChildrenUnread($cat, $owner_uid = false) {
2017-05-04 11:50:56 +00:00
if ( $cat >= 0 ) {
2017-12-01 17:15:25 +00:00
if ( ! $cat ) $cat = null ;
$sth = $pdo -> prepare ( " SELECT id FROM ttrss_feeds
WHERE ( cat_id = : cat OR ( : cat IS NULL AND cat_id IS NULL ))
2017-12-01 19:07:39 +00:00
AND owner_uid = : uid " );
move the following to Feeds:
+ static function catchup_feed($feed, $cat_view, $owner_uid = false, $mode = 'all', $search = false) {
+ static function getFeedArticles($feed, $is_cat = false, $unread_only = false,
+ static function subscribe_to_feed($url, $cat_id = 0,
+ static function getFeedIcon($id) {
+ static function getFeedTitle($id, $cat = false) {
+ static function getCategoryUnread($cat, $owner_uid = false) {
+ static function getCategoryChildrenUnread($cat, $owner_uid = false) {
2017-05-04 11:50:56 +00:00
2017-12-01 17:15:25 +00:00
$sth -> execute ([ " :cat " => $cat , " :uid " => $owner_uid ]);
move the following to Feeds:
+ static function catchup_feed($feed, $cat_view, $owner_uid = false, $mode = 'all', $search = false) {
+ static function getFeedArticles($feed, $is_cat = false, $unread_only = false,
+ static function subscribe_to_feed($url, $cat_id = 0,
+ static function getFeedIcon($id) {
+ static function getFeedTitle($id, $cat = false) {
+ static function getCategoryUnread($cat, $owner_uid = false) {
+ static function getCategoryChildrenUnread($cat, $owner_uid = false) {
2017-05-04 11:50:56 +00:00
$cat_feeds = array ();
2017-12-01 17:15:25 +00:00
while ( $line = $sth -> fetch ()) {
2017-12-17 13:24:13 +00:00
array_push ( $cat_feeds , " feed_id = " . ( int ) $line [ " id " ]);
move the following to Feeds:
+ static function catchup_feed($feed, $cat_view, $owner_uid = false, $mode = 'all', $search = false) {
+ static function getFeedArticles($feed, $is_cat = false, $unread_only = false,
+ static function subscribe_to_feed($url, $cat_id = 0,
+ static function getFeedIcon($id) {
+ static function getFeedTitle($id, $cat = false) {
+ static function getCategoryUnread($cat, $owner_uid = false) {
+ static function getCategoryChildrenUnread($cat, $owner_uid = false) {
2017-05-04 11:50:56 +00:00
}
if ( count ( $cat_feeds ) == 0 ) return 0 ;
$match_part = implode ( " OR " , $cat_feeds );
2017-12-01 17:15:25 +00:00
$sth = $pdo -> prepare ( " SELECT COUNT(int_id) AS unread
move the following to Feeds:
+ static function catchup_feed($feed, $cat_view, $owner_uid = false, $mode = 'all', $search = false) {
+ static function getFeedArticles($feed, $is_cat = false, $unread_only = false,
+ static function subscribe_to_feed($url, $cat_id = 0,
+ static function getFeedIcon($id) {
+ static function getFeedTitle($id, $cat = false) {
+ static function getCategoryUnread($cat, $owner_uid = false) {
+ static function getCategoryChildrenUnread($cat, $owner_uid = false) {
2017-05-04 11:50:56 +00:00
FROM ttrss_user_entries
WHERE unread = true AND ( $match_part )
2017-12-01 17:15:25 +00:00
AND owner_uid = ? " );
$sth -> execute ([ $owner_uid ]);
move the following to Feeds:
+ static function catchup_feed($feed, $cat_view, $owner_uid = false, $mode = 'all', $search = false) {
+ static function getFeedArticles($feed, $is_cat = false, $unread_only = false,
+ static function subscribe_to_feed($url, $cat_id = 0,
+ static function getFeedIcon($id) {
+ static function getFeedTitle($id, $cat = false) {
+ static function getCategoryUnread($cat, $owner_uid = false) {
+ static function getCategoryChildrenUnread($cat, $owner_uid = false) {
2017-05-04 11:50:56 +00:00
$unread = 0 ;
# this needs to be rewritten
2017-12-01 17:15:25 +00:00
while ( $line = $sth -> fetch ()) {
move the following to Feeds:
+ static function catchup_feed($feed, $cat_view, $owner_uid = false, $mode = 'all', $search = false) {
+ static function getFeedArticles($feed, $is_cat = false, $unread_only = false,
+ static function subscribe_to_feed($url, $cat_id = 0,
+ static function getFeedIcon($id) {
+ static function getFeedTitle($id, $cat = false) {
+ static function getCategoryUnread($cat, $owner_uid = false) {
+ static function getCategoryChildrenUnread($cat, $owner_uid = false) {
2017-05-04 11:50:56 +00:00
$unread += $line [ " unread " ];
}
return $unread ;
} else if ( $cat == - 1 ) {
return getFeedUnread ( - 1 ) + getFeedUnread ( - 2 ) + getFeedUnread ( - 3 ) + getFeedUnread ( 0 );
} else if ( $cat == - 2 ) {
2017-12-01 17:15:25 +00:00
$sth = $pdo -> prepare ( " SELECT COUNT(unread) AS unread FROM
move the following to Feeds:
+ static function catchup_feed($feed, $cat_view, $owner_uid = false, $mode = 'all', $search = false) {
+ static function getFeedArticles($feed, $is_cat = false, $unread_only = false,
+ static function subscribe_to_feed($url, $cat_id = 0,
+ static function getFeedIcon($id) {
+ static function getFeedTitle($id, $cat = false) {
+ static function getCategoryUnread($cat, $owner_uid = false) {
+ static function getCategoryChildrenUnread($cat, $owner_uid = false) {
2017-05-04 11:50:56 +00:00
ttrss_user_entries , ttrss_user_labels2
WHERE article_id = ref_id AND unread = true
2017-12-01 17:15:25 +00:00
AND ttrss_user_entries . owner_uid = ? " );
$sth -> execute ([ $owner_uid ]);
$row = $sth -> fetch ();
move the following to Feeds:
+ static function catchup_feed($feed, $cat_view, $owner_uid = false, $mode = 'all', $search = false) {
+ static function getFeedArticles($feed, $is_cat = false, $unread_only = false,
+ static function subscribe_to_feed($url, $cat_id = 0,
+ static function getFeedIcon($id) {
+ static function getFeedTitle($id, $cat = false) {
+ static function getCategoryUnread($cat, $owner_uid = false) {
+ static function getCategoryChildrenUnread($cat, $owner_uid = false) {
2017-05-04 11:50:56 +00:00
2017-12-01 17:15:25 +00:00
return $row [ " unread " ];
move the following to Feeds:
+ static function catchup_feed($feed, $cat_view, $owner_uid = false, $mode = 'all', $search = false) {
+ static function getFeedArticles($feed, $is_cat = false, $unread_only = false,
+ static function subscribe_to_feed($url, $cat_id = 0,
+ static function getFeedIcon($id) {
+ static function getFeedTitle($id, $cat = false) {
+ static function getCategoryUnread($cat, $owner_uid = false) {
+ static function getCategoryChildrenUnread($cat, $owner_uid = false) {
2017-05-04 11:50:56 +00:00
}
}
// only accepts real cats (>= 0)
static function getCategoryChildrenUnread ( $cat , $owner_uid = false ) {
if ( ! $owner_uid ) $owner_uid = $_SESSION [ " uid " ];
2017-12-01 17:15:25 +00:00
$pdo = Db :: pdo ();
$sth = $pdo -> prepare ( " SELECT id FROM ttrss_feed_categories WHERE parent_cat = ?
AND owner_uid = ? " );
$sth -> execute ([ $cat , $owner_uid ]);
move the following to Feeds:
+ static function catchup_feed($feed, $cat_view, $owner_uid = false, $mode = 'all', $search = false) {
+ static function getFeedArticles($feed, $is_cat = false, $unread_only = false,
+ static function subscribe_to_feed($url, $cat_id = 0,
+ static function getFeedIcon($id) {
+ static function getFeedTitle($id, $cat = false) {
+ static function getCategoryUnread($cat, $owner_uid = false) {
+ static function getCategoryChildrenUnread($cat, $owner_uid = false) {
2017-05-04 11:50:56 +00:00
$unread = 0 ;
2017-12-01 17:15:25 +00:00
while ( $line = $sth -> fetch ()) {
move the following to Feeds:
+ static function catchup_feed($feed, $cat_view, $owner_uid = false, $mode = 'all', $search = false) {
+ static function getFeedArticles($feed, $is_cat = false, $unread_only = false,
+ static function subscribe_to_feed($url, $cat_id = 0,
+ static function getFeedIcon($id) {
+ static function getFeedTitle($id, $cat = false) {
+ static function getCategoryUnread($cat, $owner_uid = false) {
+ static function getCategoryChildrenUnread($cat, $owner_uid = false) {
2017-05-04 11:50:56 +00:00
$unread += Feeds :: getCategoryUnread ( $line [ " id " ], $owner_uid );
$unread += Feeds :: getCategoryChildrenUnread ( $line [ " id " ], $owner_uid );
}
return $unread ;
}
2017-05-04 11:26:44 +00:00
2017-05-04 12:00:21 +00:00
static function getGlobalUnread ( $user_id = false ) {
2017-12-01 17:15:25 +00:00
if ( ! $user_id ) $user_id = $_SESSION [ " uid " ];
2017-05-04 12:00:21 +00:00
2017-12-01 17:15:25 +00:00
$pdo = Db :: pdo ();
2017-05-04 12:00:21 +00:00
2017-12-01 17:15:25 +00:00
$sth = $pdo -> prepare ( " SELECT SUM(value) AS c_id FROM ttrss_counters_cache
WHERE owner_uid = ? AND feed_id > 0 " );
$sth -> execute ([ $user_id ]);
$row = $sth -> fetch ();
2017-05-04 12:00:21 +00:00
2017-12-01 17:15:25 +00:00
return $row [ " c_id " ];
2017-05-04 12:00:21 +00:00
}
static function getCategoryTitle ( $cat_id ) {
if ( $cat_id == - 1 ) {
return __ ( " Special " );
} else if ( $cat_id == - 2 ) {
return __ ( " Labels " );
} else {
2017-12-01 17:15:25 +00:00
$pdo = Db :: pdo ();
$sth = $pdo -> prepare ( " SELECT title FROM ttrss_feed_categories WHERE
id = ? " );
$sth -> execute ([ $cat_id ]);
2017-05-04 12:00:21 +00:00
2017-12-01 17:15:25 +00:00
if ( $row = $sth -> fetch ()) {
return $row [ " title " ];
2017-05-04 12:00:21 +00:00
} else {
return __ ( " Uncategorized " );
}
}
}
static function getLabelUnread ( $label_id , $owner_uid = false ) {
if ( ! $owner_uid ) $owner_uid = $_SESSION [ " uid " ];
2017-12-01 17:15:25 +00:00
$pdo = Db :: pdo ();
$sth = $pdo -> prepare ( " SELECT COUNT(ref_id) AS unread FROM ttrss_user_entries, ttrss_user_labels2
WHERE owner_uid = ? AND unread = true AND label_id = ? AND article_id = ref_id " );
$sth -> execute ([ $owner_uid , $label_id ]);
2017-05-04 12:00:21 +00:00
2017-12-01 17:15:25 +00:00
if ( $row = $sth -> fetch ()) {
return $row [ " unread " ];
2017-05-04 12:00:21 +00:00
} else {
return 0 ;
}
}
2017-05-04 12:13:02 +00:00
static function queryFeedHeadlines ( $params ) {
2017-12-01 17:15:25 +00:00
$pdo = Db :: pdo ();
// WARNING: due to highly dynamic nature of this query its going to quote parameters
// right before adding them to SQL part
2017-05-04 12:13:02 +00:00
$feed = $params [ " feed " ];
$limit = isset ( $params [ " limit " ]) ? $params [ " limit " ] : 30 ;
$view_mode = $params [ " view_mode " ];
$cat_view = isset ( $params [ " cat_view " ]) ? $params [ " cat_view " ] : false ;
$search = isset ( $params [ " search " ]) ? $params [ " search " ] : false ;
$search_language = isset ( $params [ " search_language " ]) ? $params [ " search_language " ] : " " ;
$override_order = isset ( $params [ " override_order " ]) ? $params [ " override_order " ] : false ;
$offset = isset ( $params [ " offset " ]) ? $params [ " offset " ] : 0 ;
$owner_uid = isset ( $params [ " owner_uid " ]) ? $params [ " owner_uid " ] : $_SESSION [ " uid " ];
$since_id = isset ( $params [ " since_id " ]) ? $params [ " since_id " ] : 0 ;
$include_children = isset ( $params [ " include_children " ]) ? $params [ " include_children " ] : false ;
$ignore_vfeed_group = isset ( $params [ " ignore_vfeed_group " ]) ? $params [ " ignore_vfeed_group " ] : false ;
$override_strategy = isset ( $params [ " override_strategy " ]) ? $params [ " override_strategy " ] : false ;
$override_vfeed = isset ( $params [ " override_vfeed " ]) ? $params [ " override_vfeed " ] : false ;
$start_ts = isset ( $params [ " start_ts " ]) ? $params [ " start_ts " ] : false ;
$check_first_id = isset ( $params [ " check_first_id " ]) ? $params [ " check_first_id " ] : false ;
$skip_first_id_check = isset ( $params [ " skip_first_id_check " ]) ? $params [ " skip_first_id_check " ] : false ;
$ext_tables_part = " " ;
2017-12-01 17:15:25 +00:00
$limit_query_part = " " ;
2017-05-04 12:13:02 +00:00
$search_words = array ();
if ( $search ) {
foreach ( PluginHost :: getInstance () -> get_hooks ( PluginHost :: HOOK_SEARCH ) as $plugin ) {
list ( $search_query_part , $search_words ) = $plugin -> hook_search ( $search );
break ;
}
// fall back in case of no plugins
if ( ! $search_query_part ) {
list ( $search_query_part , $search_words ) = search_to_sql ( $search , $search_language );
}
$search_query_part .= " AND " ;
} else {
$search_query_part = " " ;
}
if ( $since_id ) {
2017-12-01 17:52:30 +00:00
$since_id_part = " ttrss_entries.id > " . $pdo -> quote ( $since_id ) . " AND " ;
2017-05-04 12:13:02 +00:00
} else {
$since_id_part = " " ;
}
$view_query_part = " " ;
if ( $view_mode == " adaptive " ) {
if ( $search ) {
$view_query_part = " " ;
} else if ( $feed != - 1 ) {
$unread = getFeedUnread ( $feed , $cat_view );
if ( $cat_view && $feed > 0 && $include_children )
$unread += Feeds :: getCategoryChildrenUnread ( $feed );
if ( $unread > 0 ) {
$view_query_part = " unread = true AND " ;
}
}
}
if ( $view_mode == " marked " ) {
$view_query_part = " marked = true AND " ;
}
if ( $view_mode == " has_note " ) {
$view_query_part = " (note IS NOT NULL AND note != '') AND " ;
}
if ( $view_mode == " published " ) {
$view_query_part = " published = true AND " ;
}
if ( $view_mode == " unread " && $feed != - 6 ) {
$view_query_part = " unread = true AND " ;
}
if ( $limit > 0 ) {
2017-12-01 18:07:55 +00:00
$limit_query_part = " LIMIT " . ( int ) $limit ;
2017-05-04 12:13:02 +00:00
}
$allow_archived = false ;
$vfeed_query_part = " " ;
/* tags */
if ( ! is_numeric ( $feed )) {
$query_strategy_part = " true " ;
$vfeed_query_part = " (SELECT title FROM ttrss_feeds WHERE
id = feed_id ) as feed_title , " ;
} else if ( $feed > 0 ) {
if ( $cat_view ) {
if ( $feed > 0 ) {
if ( $include_children ) {
# sub-cats
$subcats = Feeds :: getChildCategories ( $feed , $owner_uid );
array_push ( $subcats , $feed );
2017-12-17 13:24:13 +00:00
$subcats = array_map ( " intval " , $subcats );
2017-05-04 12:13:02 +00:00
$query_strategy_part = " cat_id IN ( " .
implode ( " , " , $subcats ) . " ) " ;
} else {
2017-12-01 17:52:30 +00:00
$query_strategy_part = " cat_id = " . $pdo -> quote ( $feed );
2017-05-04 12:13:02 +00:00
}
} else {
$query_strategy_part = " cat_id IS NULL " ;
}
$vfeed_query_part = " ttrss_feeds.title AS feed_title, " ;
} else {
2017-12-01 17:52:30 +00:00
$query_strategy_part = " feed_id = " . $pdo -> quote ( $feed );
2017-05-04 12:13:02 +00:00
}
} else if ( $feed == 0 && ! $cat_view ) { // archive virtual feed
$query_strategy_part = " feed_id IS NULL " ;
$allow_archived = true ;
} else if ( $feed == 0 && $cat_view ) { // uncategorized
$query_strategy_part = " cat_id IS NULL AND feed_id IS NOT NULL " ;
$vfeed_query_part = " ttrss_feeds.title AS feed_title, " ;
} else if ( $feed == - 1 ) { // starred virtual feed
$query_strategy_part = " marked = true " ;
$vfeed_query_part = " ttrss_feeds.title AS feed_title, " ;
$allow_archived = true ;
if ( ! $override_order ) {
$override_order = " last_marked DESC, date_entered DESC, updated DESC " ;
}
} else if ( $feed == - 2 ) { // published virtual feed OR labels category
if ( ! $cat_view ) {
$query_strategy_part = " published = true " ;
$vfeed_query_part = " ttrss_feeds.title AS feed_title, " ;
$allow_archived = true ;
if ( ! $override_order ) {
$override_order = " last_published DESC, date_entered DESC, updated DESC " ;
}
} else {
$vfeed_query_part = " ttrss_feeds.title AS feed_title, " ;
$ext_tables_part = " ttrss_labels2,ttrss_user_labels2, " ;
$query_strategy_part = " ttrss_labels2.id = ttrss_user_labels2.label_id AND
ttrss_user_labels2 . article_id = ref_id " ;
}
} else if ( $feed == - 6 ) { // recently read
$query_strategy_part = " unread = false AND last_read IS NOT NULL " ;
if ( DB_TYPE == " pgsql " ) {
$query_strategy_part .= " AND last_read > NOW() - INTERVAL '1 DAY' " ;
} else {
$query_strategy_part .= " AND last_read > DATE_SUB(NOW(), INTERVAL 1 DAY) " ;
}
$vfeed_query_part = " ttrss_feeds.title AS feed_title, " ;
$allow_archived = true ;
$ignore_vfeed_group = true ;
if ( ! $override_order ) $override_order = " last_read DESC " ;
} else if ( $feed == - 3 ) { // fresh virtual feed
$query_strategy_part = " unread = true AND score >= 0 " ;
2017-12-01 17:52:30 +00:00
$intl = ( int ) get_pref ( " FRESH_ARTICLE_MAX_AGE " , $owner_uid );
2017-05-04 12:13:02 +00:00
if ( DB_TYPE == " pgsql " ) {
$query_strategy_part .= " AND date_entered > NOW() - INTERVAL ' $intl hour' " ;
} else {
$query_strategy_part .= " AND date_entered > DATE_SUB(NOW(), INTERVAL $intl HOUR) " ;
}
$vfeed_query_part = " ttrss_feeds.title AS feed_title, " ;
} else if ( $feed == - 4 ) { // all articles virtual feed
$allow_archived = true ;
$query_strategy_part = " true " ;
$vfeed_query_part = " ttrss_feeds.title AS feed_title, " ;
} else if ( $feed <= LABEL_BASE_INDEX ) { // labels
2017-05-04 12:57:40 +00:00
$label_id = Labels :: feed_to_label_id ( $feed );
2017-05-04 12:13:02 +00:00
2017-12-01 17:52:30 +00:00
$query_strategy_part = " label_id = " . $pdo -> quote ( $label_id ) . " AND
2017-05-04 12:13:02 +00:00
ttrss_labels2 . id = ttrss_user_labels2 . label_id AND
ttrss_user_labels2 . article_id = ref_id " ;
$vfeed_query_part = " ttrss_feeds.title AS feed_title, " ;
$ext_tables_part = " ttrss_labels2,ttrss_user_labels2, " ;
$allow_archived = true ;
} else {
$query_strategy_part = " true " ;
}
$order_by = " score DESC, date_entered DESC, updated DESC " ;
if ( $override_order ) {
$order_by = $override_order ;
}
if ( $override_strategy ) {
$query_strategy_part = $override_strategy ;
}
if ( $override_vfeed ) {
$vfeed_query_part = $override_vfeed ;
}
if ( $search ) {
$feed_title = T_sprintf ( " Search results: %s " , $search );
} else {
if ( $cat_view ) {
$feed_title = Feeds :: getCategoryTitle ( $feed );
} else {
if ( is_numeric ( $feed ) && $feed > 0 ) {
2017-12-01 17:15:25 +00:00
$ssth = $pdo -> prepare ( " SELECT title,site_url,last_error,last_updated
FROM ttrss_feeds WHERE id = ? AND owner_uid = ? " );
$ssth -> execute ([ $feed , $owner_uid ]);
$row = $ssth -> fetch ();
$feed_title = $row [ " title " ];
$feed_site_url = $row [ " site_url " ];
$last_error = $row [ " last_error " ];
$last_updated = $row [ " last_updated " ];
2017-05-04 12:13:02 +00:00
} else {
$feed_title = Feeds :: getFeedTitle ( $feed );
}
}
}
$content_query_part = " content, " ;
if ( $limit_query_part ) {
2017-12-01 18:07:55 +00:00
$offset_query_part = " OFFSET " . ( int ) $offset ;
2017-05-04 12:13:02 +00:00
} else {
$offset_query_part = " " ;
}
if ( is_numeric ( $feed )) {
// proper override_order applied above
if ( $vfeed_query_part && ! $ignore_vfeed_group && get_pref ( 'VFEED_GROUP_BY_FEED' , $owner_uid )) {
if ( ! $override_order ) {
2017-12-03 19:49:57 +00:00
$order_by = " ttrss_feeds.title, " . $order_by ;
2017-05-04 12:13:02 +00:00
} else {
2017-12-03 19:49:57 +00:00
$order_by = " ttrss_feeds.title, " . $override_order ;
2017-05-04 12:13:02 +00:00
}
}
if ( ! $allow_archived ) {
$from_qpart = " ${ ext_tables_part } ttrss_entries LEFT JOIN ttrss_user_entries ON (ref_id = ttrss_entries.id),ttrss_feeds " ;
$feed_check_qpart = " ttrss_user_entries.feed_id = ttrss_feeds.id AND " ;
} else {
$from_qpart = " ${ ext_tables_part } ttrss_entries LEFT JOIN ttrss_user_entries ON (ref_id = ttrss_entries.id)
LEFT JOIN ttrss_feeds ON ( feed_id = ttrss_feeds . id ) " ;
}
if ( $vfeed_query_part ) $vfeed_query_part .= " favicon_avg_color, " ;
if ( $start_ts ) {
$start_ts_formatted = date ( " Y/m/d H:i:s " , strtotime ( $start_ts ));
$start_ts_query_part = " date_entered >= ' $start_ts_formatted ' AND " ;
} else {
$start_ts_query_part = " " ;
}
$first_id = 0 ;
$first_id_query_strategy_part = $query_strategy_part ;
if ( $feed == - 3 )
$first_id_query_strategy_part = " true " ;
if ( DB_TYPE == " pgsql " ) {
$sanity_interval_qpart = " date_entered >= NOW() - INTERVAL '1 hour' AND " ;
} else {
$sanity_interval_qpart = " date_entered >= DATE_SUB(NOW(), INTERVAL 1 hour) AND " ;
}
if ( ! $search && ! $skip_first_id_check ) {
// if previous topmost article id changed that means our current pagination is no longer valid
$query = " SELECT DISTINCT
ttrss_feeds . title ,
date_entered ,
guid ,
ttrss_entries . id ,
ttrss_entries . title ,
updated ,
score ,
marked ,
published ,
last_marked ,
last_published ,
last_read
FROM
$from_qpart
WHERE
$feed_check_qpart
2017-12-01 17:52:30 +00:00
ttrss_user_entries . owner_uid = " . $pdo->quote ( $owner_uid ). " AND
2017-05-04 12:13:02 +00:00
$search_query_part
$start_ts_query_part
$since_id_part
$sanity_interval_qpart
$first_id_query_strategy_part ORDER BY $order_by LIMIT 1 " ;
2017-12-17 13:24:13 +00:00
/* if ( $_REQUEST [ " debug " ]) {
2017-05-04 12:13:02 +00:00
print $query ;
2017-12-17 13:24:13 +00:00
} */
2017-05-04 12:13:02 +00:00
2017-12-01 17:25:13 +00:00
$res = $pdo -> query ( $query );
2017-12-01 17:15:25 +00:00
2017-12-01 17:25:13 +00:00
if ( $row = $res -> fetch ()) {
$first_id = ( int ) $row [ " id " ];
2017-05-04 12:13:02 +00:00
if ( $offset > 0 && $first_id && $check_first_id && $first_id != $check_first_id ) {
return array ( - 1 , $feed_title , $feed_site_url , $last_error , $last_updated , $search_words , $first_id );
}
}
}
$query = " SELECT DISTINCT
date_entered ,
guid ,
ttrss_entries . id , ttrss_entries . title ,
updated ,
label_cache ,
tag_cache ,
always_display_enclosures ,
site_url ,
note ,
num_comments ,
comments ,
int_id ,
uuid ,
lang ,
hide_images ,
unread , feed_id , marked , published , link , last_read , orig_feed_id ,
last_marked , last_published ,
$vfeed_query_part
$content_query_part
author , score
FROM
$from_qpart
WHERE
$feed_check_qpart
2017-12-01 17:52:30 +00:00
ttrss_user_entries . owner_uid = " . $pdo->quote ( $owner_uid ). " AND
2017-05-04 12:13:02 +00:00
$search_query_part
$start_ts_query_part
$view_query_part
$since_id_part
$query_strategy_part ORDER BY $order_by
$limit_query_part $offset_query_part " ;
2017-12-17 13:24:13 +00:00
//if ($_REQUEST["debug"]) print $query;
2017-05-04 12:13:02 +00:00
2017-12-01 17:25:13 +00:00
$res = $pdo -> query ( $query );
2017-05-04 12:13:02 +00:00
} else {
// browsing by tag
$query = " SELECT DISTINCT
date_entered ,
guid ,
note ,
ttrss_entries . id as id ,
title ,
updated ,
unread ,
feed_id ,
orig_feed_id ,
marked ,
num_comments ,
comments ,
int_id ,
tag_cache ,
label_cache ,
link ,
lang ,
uuid ,
last_read ,
( SELECT hide_images FROM ttrss_feeds WHERE id = feed_id ) AS hide_images ,
last_marked , last_published ,
$since_id_part
$vfeed_query_part
$content_query_part
author , score
FROM ttrss_entries , ttrss_user_entries , ttrss_tags
WHERE
ref_id = ttrss_entries . id AND
2017-12-01 17:52:30 +00:00
ttrss_user_entries . owner_uid = " . $pdo->quote ( $owner_uid ). " AND
2017-05-04 12:13:02 +00:00
post_int_id = int_id AND
2017-12-01 17:52:30 +00:00
tag_name = " . $pdo->quote ( $feed ). " AND
2017-05-04 12:13:02 +00:00
$view_query_part
$search_query_part
$query_strategy_part ORDER BY $order_by
$limit_query_part $offset_query_part " ;
if ( $_REQUEST [ " debug " ]) print $query ;
2017-12-01 17:25:13 +00:00
$res = $pdo -> query ( $query );
2017-05-04 12:13:02 +00:00
}
2017-12-01 17:25:13 +00:00
return array ( $res , $feed_title , $feed_site_url , $last_error , $last_updated , $search_words , $first_id );
2017-05-04 12:13:02 +00:00
}
static function getParentCategories ( $cat , $owner_uid ) {
$rv = array ();
2017-12-01 17:25:13 +00:00
$pdo = Db :: pdo ();
$sth = $pdo -> prepare ( " SELECT parent_cat FROM ttrss_feed_categories
WHERE id = ? AND parent_cat IS NOT NULL AND owner_uid = ? " );
$sth -> execute ([ $cat , $owner_uid ]);
2017-05-04 12:13:02 +00:00
2017-12-01 17:25:13 +00:00
while ( $line = $sth -> fetch ()) {
2017-05-04 12:13:02 +00:00
array_push ( $rv , $line [ " parent_cat " ]);
$rv = array_merge ( $rv , Feeds :: getParentCategories ( $line [ " parent_cat " ], $owner_uid ));
}
return $rv ;
}
static function getChildCategories ( $cat , $owner_uid ) {
$rv = array ();
2017-12-01 17:25:13 +00:00
$pdo = Db :: pdo ();
$sth = $pdo -> prepare ( " SELECT id FROM ttrss_feed_categories
WHERE parent_cat = ? AND owner_uid = ? " );
$sth -> execute ([ $cat , $owner_uid ]);
2017-05-04 12:13:02 +00:00
2017-12-01 17:25:13 +00:00
while ( $line = $sth -> fetch ()) {
2017-05-04 12:13:02 +00:00
array_push ( $rv , $line [ " id " ]);
$rv = array_merge ( $rv , Feeds :: getChildCategories ( $line [ " id " ], $owner_uid ));
}
return $rv ;
}
2017-05-04 12:36:36 +00:00
static function getFeedCategory ( $feed ) {
2017-12-01 17:25:13 +00:00
$pdo = Db :: pdo ();
2017-05-04 12:36:36 +00:00
2017-12-01 17:25:13 +00:00
$sth = $pdo -> prepare ( " SELECT cat_id FROM ttrss_feeds
WHERE id = ? " );
$sth -> execute ([ $feed ]);
if ( $row = $sth -> fetch ()) {
return $row [ " cat_id " ];
2017-05-04 12:36:36 +00:00
} else {
return false ;
}
}
2013-02-21 14:58:06 +00:00
}
move the following to Feeds:
+ static function catchup_feed($feed, $cat_view, $owner_uid = false, $mode = 'all', $search = false) {
+ static function getFeedArticles($feed, $is_cat = false, $unread_only = false,
+ static function subscribe_to_feed($url, $cat_id = 0,
+ static function getFeedIcon($id) {
+ static function getFeedTitle($id, $cat = false) {
+ static function getCategoryUnread($cat, $owner_uid = false) {
+ static function getCategoryChildrenUnread($cat, $owner_uid = false) {
2017-05-04 11:50:56 +00:00