diff --git a/classes/article.php b/classes/article.php
index ec0276406..2f49b1827 100644
--- a/classes/article.php
+++ b/classes/article.php
@@ -1,176 +1,176 @@
-link, "SELECT link FROM ttrss_entries, ttrss_user_entries
- WHERE id = '$id' AND id = ref_id AND owner_uid = '".$_SESSION['uid']."'
- LIMIT 1");
-
- if (db_num_rows($result) == 1) {
- $article_url = db_fetch_result($result, 0, 'link');
- $article_url = str_replace("\n", "", $article_url);
-
- header("Location: $article_url");
- return;
-
- } else {
- print_error(__("Article not found."));
- }
- }
-
- function view() {
- $id = db_escape_string($_REQUEST["id"]);
- $cids = explode(",", db_escape_string($_REQUEST["cids"]));
- $mode = db_escape_string($_REQUEST["mode"]);
- $omode = db_escape_string($_REQUEST["omode"]);
-
- // in prefetch mode we only output requested cids, main article
- // just gets marked as read (it already exists in client cache)
-
- $articles = array();
-
- if ($mode == "") {
- array_push($articles, format_article($this->link, $id, false));
- } else if ($mode == "zoom") {
- array_push($articles, format_article($this->link, $id, true, true));
- } else if ($mode == "raw") {
- if ($_REQUEST['html']) {
- header("Content-Type: text/html");
- print '';
- }
-
- $article = format_article($this->link, $id, false);
- print $article['content'];
- return;
- }
-
- $this->catchupArticleById($this->link, $id, 0);
-
- if (!$_SESSION["bw_limit"]) {
- foreach ($cids as $cid) {
- if ($cid) {
- array_push($articles, format_article($this->link, $cid, false, false));
- }
- }
- }
-
- print json_encode($articles);
- }
-
- private function catchupArticleById($link, $id, $cmode) {
-
- if ($cmode == 0) {
- db_query($link, "UPDATE ttrss_user_entries SET
- unread = false,last_read = NOW()
- WHERE ref_id = '$id' AND owner_uid = " . $_SESSION["uid"]);
- } else if ($cmode == 1) {
- db_query($link, "UPDATE ttrss_user_entries SET
- unread = true
- WHERE ref_id = '$id' AND owner_uid = " . $_SESSION["uid"]);
- } else {
- db_query($link, "UPDATE ttrss_user_entries SET
- unread = NOT unread,last_read = NOW()
- WHERE ref_id = '$id' AND owner_uid = " . $_SESSION["uid"]);
- }
-
- $feed_id = getArticleFeed($link, $id);
- ccache_update($link, $feed_id, $_SESSION["uid"]);
- }
-
- static function create_published_article($link, $title, $url, $content, $labels_str,
- $owner_uid) {
-
- $guid = sha1($url . $owner_uid); // include owner_uid to prevent global GUID clash
- $content_hash = sha1($content);
-
- if ($labels_str != "") {
- $labels = explode(",", $labels_str);
- } else {
- $labels = array();
- }
-
- $rc = false;
-
- if (!$title) $title = $url;
- if (!$title && !$url) return false;
-
- if (filter_var($url, FILTER_VALIDATE_URL) === FALSE) return false;
-
- db_query($link, "BEGIN");
-
- // only check for our user data here, others might have shared this with different content etc
- $result = db_query($link, "SELECT id FROM ttrss_entries, ttrss_user_entries WHERE
- link = '$url' AND ref_id = id AND owner_uid = '$owner_uid' LIMIT 1");
-
- if (db_num_rows($result) != 0) {
- $ref_id = db_fetch_result($result, 0, "id");
-
- $result = db_query($link, "SELECT int_id FROM ttrss_user_entries WHERE
- ref_id = '$ref_id' AND owner_uid = '$owner_uid' LIMIT 1");
-
- if (db_num_rows($result) != 0) {
- $int_id = db_fetch_result($result, 0, "int_id");
-
- db_query($link, "UPDATE ttrss_entries SET
- content = '$content', content_hash = '$content_hash' WHERE id = '$ref_id'");
-
- db_query($link, "UPDATE ttrss_user_entries SET published = true WHERE
- int_id = '$int_id' AND owner_uid = '$owner_uid'");
- } else {
-
- db_query($link, "INSERT INTO ttrss_user_entries
- (ref_id, uuid, feed_id, orig_feed_id, owner_uid, published, tag_cache, label_cache, last_read, note, unread)
- VALUES
- ('$ref_id', '', NULL, NULL, $owner_uid, true, '', '', NOW(), '', false)");
- }
-
- if (count($labels) != 0) {
- foreach ($labels as $label) {
- label_add_article($link, $ref_id, trim($label), $owner_uid);
- }
- }
-
- $rc = true;
-
- } else {
- $result = db_query($link, "INSERT INTO ttrss_entries
- (title, guid, link, updated, content, content_hash, date_entered, date_updated)
- VALUES
- ('$title', '$guid', '$url', NOW(), '$content', '$content_hash', NOW(), NOW())");
-
- $result = db_query($link, "SELECT id FROM ttrss_entries WHERE guid = '$guid'");
-
- if (db_num_rows($result) != 0) {
- $ref_id = db_fetch_result($result, 0, "id");
-
- db_query($link, "INSERT INTO ttrss_user_entries
- (ref_id, uuid, feed_id, orig_feed_id, owner_uid, published, tag_cache, label_cache, last_read, note, unread)
- VALUES
- ('$ref_id', '', NULL, NULL, $owner_uid, true, '', '', NOW(), '', false)");
-
- if (count($labels) != 0) {
- foreach ($labels as $label) {
- label_add_article($link, $ref_id, trim($label), $owner_uid);
- }
- }
-
- $rc = true;
- }
- }
-
- db_query($link, "COMMIT");
-
- return $rc;
- }
-
-
-
-}
+link, "SELECT link FROM ttrss_entries, ttrss_user_entries
+ WHERE id = '$id' AND id = ref_id AND owner_uid = '".$_SESSION['uid']."'
+ LIMIT 1");
+
+ if (db_num_rows($result) == 1) {
+ $article_url = db_fetch_result($result, 0, 'link');
+ $article_url = str_replace("\n", "", $article_url);
+
+ header("Location: $article_url");
+ return;
+
+ } else {
+ print_error(__("Article not found."));
+ }
+ }
+
+ function view() {
+ $id = db_escape_string($_REQUEST["id"]);
+ $cids = explode(",", db_escape_string($_REQUEST["cids"]));
+ $mode = db_escape_string($_REQUEST["mode"]);
+ $omode = db_escape_string($_REQUEST["omode"]);
+
+ // in prefetch mode we only output requested cids, main article
+ // just gets marked as read (it already exists in client cache)
+
+ $articles = array();
+
+ if ($mode == "") {
+ array_push($articles, format_article($this->link, $id, false));
+ } else if ($mode == "zoom") {
+ array_push($articles, format_article($this->link, $id, true, true));
+ } else if ($mode == "raw") {
+ if ($_REQUEST['html']) {
+ header("Content-Type: text/html");
+ print '';
+ }
+
+ $article = format_article($this->link, $id, false);
+ print $article['content'];
+ return;
+ }
+
+ $this->catchupArticleById($this->link, $id, 0);
+
+ if (!$_SESSION["bw_limit"]) {
+ foreach ($cids as $cid) {
+ if ($cid) {
+ array_push($articles, format_article($this->link, $cid, false, false));
+ }
+ }
+ }
+
+ print json_encode($articles);
+ }
+
+ private function catchupArticleById($link, $id, $cmode) {
+
+ if ($cmode == 0) {
+ db_query($link, "UPDATE ttrss_user_entries SET
+ unread = false,last_read = NOW()
+ WHERE ref_id = '$id' AND owner_uid = " . $_SESSION["uid"]);
+ } else if ($cmode == 1) {
+ db_query($link, "UPDATE ttrss_user_entries SET
+ unread = true
+ WHERE ref_id = '$id' AND owner_uid = " . $_SESSION["uid"]);
+ } else {
+ db_query($link, "UPDATE ttrss_user_entries SET
+ unread = NOT unread,last_read = NOW()
+ WHERE ref_id = '$id' AND owner_uid = " . $_SESSION["uid"]);
+ }
+
+ $feed_id = getArticleFeed($link, $id);
+ ccache_update($link, $feed_id, $_SESSION["uid"]);
+ }
+
+ static function create_published_article($link, $title, $url, $content, $labels_str,
+ $owner_uid) {
+
+ $guid = sha1($url . $owner_uid); // include owner_uid to prevent global GUID clash
+ $content_hash = sha1($content);
+
+ if ($labels_str != "") {
+ $labels = explode(",", $labels_str);
+ } else {
+ $labels = array();
+ }
+
+ $rc = false;
+
+ if (!$title) $title = $url;
+ if (!$title && !$url) return false;
+
+ if (filter_var($url, FILTER_VALIDATE_URL) === FALSE) return false;
+
+ db_query($link, "BEGIN");
+
+ // only check for our user data here, others might have shared this with different content etc
+ $result = db_query($link, "SELECT id FROM ttrss_entries, ttrss_user_entries WHERE
+ link = '$url' AND ref_id = id AND owner_uid = '$owner_uid' LIMIT 1");
+
+ if (db_num_rows($result) != 0) {
+ $ref_id = db_fetch_result($result, 0, "id");
+
+ $result = db_query($link, "SELECT int_id FROM ttrss_user_entries WHERE
+ ref_id = '$ref_id' AND owner_uid = '$owner_uid' LIMIT 1");
+
+ if (db_num_rows($result) != 0) {
+ $int_id = db_fetch_result($result, 0, "int_id");
+
+ db_query($link, "UPDATE ttrss_entries SET
+ content = '$content', content_hash = '$content_hash' WHERE id = '$ref_id'");
+
+ db_query($link, "UPDATE ttrss_user_entries SET published = true WHERE
+ int_id = '$int_id' AND owner_uid = '$owner_uid'");
+ } else {
+
+ db_query($link, "INSERT INTO ttrss_user_entries
+ (ref_id, uuid, feed_id, orig_feed_id, owner_uid, published, tag_cache, label_cache, last_read, note, unread)
+ VALUES
+ ('$ref_id', '', NULL, NULL, $owner_uid, true, '', '', NOW(), '', false)");
+ }
+
+ if (count($labels) != 0) {
+ foreach ($labels as $label) {
+ label_add_article($link, $ref_id, trim($label), $owner_uid);
+ }
+ }
+
+ $rc = true;
+
+ } else {
+ $result = db_query($link, "INSERT INTO ttrss_entries
+ (title, guid, link, updated, content, content_hash, date_entered, date_updated)
+ VALUES
+ ('$title', '$guid', '$url', NOW(), '$content', '$content_hash', NOW(), NOW())");
+
+ $result = db_query($link, "SELECT id FROM ttrss_entries WHERE guid = '$guid'");
+
+ if (db_num_rows($result) != 0) {
+ $ref_id = db_fetch_result($result, 0, "id");
+
+ db_query($link, "INSERT INTO ttrss_user_entries
+ (ref_id, uuid, feed_id, orig_feed_id, owner_uid, published, tag_cache, label_cache, last_read, note, unread)
+ VALUES
+ ('$ref_id', '', NULL, NULL, $owner_uid, true, '', '', NOW(), '', false)");
+
+ if (count($labels) != 0) {
+ foreach ($labels as $label) {
+ label_add_article($link, $ref_id, trim($label), $owner_uid);
+ }
+ }
+
+ $rc = true;
+ }
+ }
+
+ db_query($link, "COMMIT");
+
+ return $rc;
+ }
+
+
+
+}
diff --git a/classes/feeds.php b/classes/feeds.php
index 40e7648ff..b257ca35e 100644
--- a/classes/feeds.php
+++ b/classes/feeds.php
@@ -1,982 +1,982 @@
-";
- $reply .= "";
-
- if ($feed_site_url) {
- $target = "target=\"_blank\"";
- $reply .= "".
- truncate_string($feed_title,30)."";
-
- if ($error) {
- $reply .= " (Error)";
- }
-
- } else {
- $reply .= $feed_title;
- }
-
- $reply .= "";
-
- $reply .= "
-
-
";
-
- $reply .= "";
-
- // left part
-
- $reply .= __('Select:')."
- ".__('All').",
- ".__('Unread').",
- ".__('Invert').",
- ".__('None')."";
-
- $reply .= " ";
-
- $reply .= "";
-
- //$reply .= "";
-
- //$reply .= " 0 && is_numeric($feed)) {
- // Update the feed if required with some basic flood control
-
- $result = db_query($this->link,
- "SELECT cache_images,cache_content,".SUBSTRING_FOR_DATE."(last_updated,1,19) AS last_updated
- FROM ttrss_feeds WHERE id = '$feed'");
-
- if (db_num_rows($result) != 0) {
- $last_updated = strtotime(db_fetch_result($result, 0, "last_updated"));
- $cache_images = sql_bool_to_bool(db_fetch_result($result, 0, "cache_images"));
- $cache_content = sql_bool_to_bool(db_fetch_result($result, 0, "cache_content"));
-
- if (!$cache_images && !$cache_content && time() - $last_updated > 120 || isset($_REQUEST['DevForceUpdate'])) {
- include "rssfuncs.php";
- update_rss_feed($this->link, $feed, true, true);
- } else {
- db_query($this->link, "UPDATE ttrss_feeds SET last_updated = '1970-01-01', last_update_started = '1970-01-01'
- WHERE id = '$feed'");
- }
- }
- }
-
- if ($method_split[0] == "MarkAllReadGR") {
- catchup_feed($this->link, $method_split[1], false);
- }
-
- // FIXME: might break tag display?
-
- if (is_numeric($feed) && $feed > 0 && !$cat_view) {
- $result = db_query($this->link,
- "SELECT id FROM ttrss_feeds WHERE id = '$feed' LIMIT 1");
-
- if (db_num_rows($result) == 0) {
- $reply['content'] = "
".__('Feed not found.')."
";
- }
- }
-
- if (is_numeric($feed) && $feed > 0) {
-
- $result = db_query($this->link, "SELECT rtl_content FROM ttrss_feeds
- WHERE id = '$feed' AND owner_uid = " . $_SESSION["uid"]);
-
- if (db_num_rows($result) == 1) {
- $rtl_content = sql_bool_to_bool(db_fetch_result($result, 0, "rtl_content"));
- } else {
- $rtl_content = false;
- }
-
- if ($rtl_content) {
- $rtl_tag = "dir=\"RTL\"";
- } else {
- $rtl_tag = "";
- }
- } else {
- $rtl_tag = "";
- $rtl_content = false;
- }
-
- @$search = db_escape_string($_REQUEST["query"]);
-
- if ($search) {
- $disable_cache = true;
- }
-
- @$search_mode = db_escape_string($_REQUEST["search_mode"]);
- $match_on = "both"; // deprecated, TODO: remove
-
- if ($_REQUEST["debug"]) $timing_info = print_checkpoint("H0", $timing_info);
-
-// error_log("format_headlines_list: [" . $feed . "] method [" . $method . "]");
- if( $search_mode == '' && $method != '' ){
- $search_mode = $method;
- }
-// error_log("search_mode: " . $search_mode);
- $qfh_ret = queryFeedHeadlines($this->link, $feed, $limit, $view_mode, $cat_view,
- $search, $search_mode, $match_on, $override_order, $offset, 0,
- false, 0, $include_children);
-
- if ($_REQUEST["debug"]) $timing_info = print_checkpoint("H1", $timing_info);
-
- $result = $qfh_ret[0];
- $feed_title = $qfh_ret[1];
- $feed_site_url = $qfh_ret[2];
- $last_error = $qfh_ret[3];
- $cache_content = true;
-
- $vgroup_last_feed = $vgr_last_feed;
-
- $reply['toolbar'] = $this->format_headline_subtoolbar($feed_site_url,
- $feed_title,
- $feed, $cat_view, $search, $match_on, $search_mode, $view_mode,
- $last_error);
-
- $headlines_count = db_num_rows($result);
-
- /* if (get_pref($this->link, 'COMBINED_DISPLAY_MODE')) {
- $button_plugins = array();
- foreach (explode(",", ARTICLE_BUTTON_PLUGINS) as $p) {
- $pclass = "button_" . trim($p);
-
- if (class_exists($pclass)) {
- $plugin = new $pclass($link);
- array_push($button_plugins, $plugin);
- }
- }
- } */
-
- global $pluginhost;
-
- if (db_num_rows($result) > 0) {
-
- $lnum = $offset;
-
- $num_unread = 0;
- $cur_feed_title = '';
-
- $fresh_intl = get_pref($this->link, "FRESH_ARTICLE_MAX_AGE") * 60 * 60;
-
- if ($_REQUEST["debug"]) $timing_info = print_checkpoint("PS", $timing_info);
-
- while ($line = db_fetch_assoc($result)) {
- $class = ($lnum % 2) ? "even" : "odd";
-
- $id = $line["id"];
- $feed_id = $line["feed_id"];
- $label_cache = $line["label_cache"];
- $labels = false;
- $label_row_style = "";
-
- if ($label_cache) {
- $label_cache = json_decode($label_cache, true);
-
- if ($label_cache) {
- if ($label_cache["no-labels"] == 1)
- $labels = array();
- else
- $labels = $label_cache;
- }
- }
-
- if (!is_array($labels)) $labels = get_article_labels($this->link, $id);
-
- if (count($labels) > 0) {
- for ($i = 0; $i < min(4, count($labels)); $i++) {
- $bg = rgb2hsl(_color_unpack($labels[$i][3]));
-
- if ($bg && $bg[1] > 0) {
- $bg[1] = 0.1;
- $bg[2] = 1;
-
- $bg = _color_pack(hsl2rgb($bg));
- $label_row_style = $this->make_gradient($bg, $class);;
-
- break;
- }
- }
- }
-
- $labels_str = "";
- $labels_str .= format_article_labels($labels, $id);
- $labels_str .= "";
-
- if (count($topmost_article_ids) < 3) {
- array_push($topmost_article_ids, $id);
- }
-
- if ($line["unread"] == "t" || $line["unread"] == "1") {
- $class .= " Unread";
- ++$num_unread;
- $is_unread = true;
- } else {
- $is_unread = false;
- }
-
- if ($line["marked"] == "t" || $line["marked"] == "1") {
- $marked_pic = "
link, 'images/mark_set.svg')."\"
- class=\"markedPic\" alt=\"Unstar article\"
- onclick='javascript:toggleMark($id)'>";
- } else {
- $marked_pic = "
link, 'images/mark_unset.svg')."\"
- class=\"markedPic\" alt=\"Star article\"
- onclick='javascript:toggleMark($id)'>";
- }
-
- if ($line["published"] == "t" || $line["published"] == "1") {
- $published_pic = "
link,
- 'images/pub_set.svg')."\"
- class=\"markedPic\"
- alt=\"Unpublish article\" onclick='javascript:togglePub($id)'>";
- } else {
- $published_pic = "
link,
- 'images/pub_unset.svg')."\"
- class=\"markedPic\"
- alt=\"Publish article\" onclick='javascript:togglePub($id)'>";
- }
-
-# $content_link = "" .
-# $line["title"] . "";
-
-# $content_link = "" .
-# $line["title"] . "";
-
-# $content_link = "" .
-# $line["title"] . "";
-
- $updated_fmt = make_local_datetime($this->link, $line["updated_noms"], false);
-
- if (get_pref($this->link, 'SHOW_CONTENT_PREVIEW')) {
- $content_preview = truncate_string(strip_tags($line["content_preview"]),
- 100);
- }
-
- $score = $line["score"];
-
- $score_pic = theme_image($this->link,
- "images/" . get_score_pic($score));
-
-/* $score_title = __("(Click to change)");
- $score_pic = "
"; */
-
- $score_pic = "
";
-
- if ($score > 500) {
- $hlc_suffix = "H";
- } else if ($score < -100) {
- $hlc_suffix = "L";
- } else {
- $hlc_suffix = "";
- }
-
- $entry_author = $line["author"];
-
- if ($entry_author) {
- $entry_author = " - $entry_author";
- }
-
- $has_feed_icon = feed_has_icon($feed_id);
-
- if ($has_feed_icon) {
- $feed_icon_img = "
";
- } else {
- $feed_icon_img = "
";
- }
-
- if (!get_pref($this->link, 'COMBINED_DISPLAY_MODE')) {
-
- if (get_pref($this->link, 'VFEED_GROUP_BY_FEED')) {
- if ($feed_id != $vgroup_last_feed && $line["feed_title"]) {
-
- $cur_feed_title = $line["feed_title"];
- $vgroup_last_feed = $feed_id;
-
- $cur_feed_title = htmlspecialchars($cur_feed_title);
-
- $vf_catchup_link = "(".__('mark as read').")";
-
- $reply['content'] .= "";
-
- }
- }
-
- $mouseover_attrs = "onmouseover='postMouseIn($id)'
- onmouseout='postMouseOut($id)'";
-
- $reply['content'] .= "";
-
- $reply['content'] .= "
";
-
- $reply['content'] .= "";
-
- $reply['content'] .= "$marked_pic";
- $reply['content'] .= "$published_pic";
-
- $reply['content'] .= "
";
-
- $reply['content'] .= "
";
-
- $reply['content'] .= "
$updated_fmt";
- $reply['content'] .= "
";
-
- $reply['content'] .= $score_pic;
-
- if ($line["feed_title"] && !get_pref($this->link, 'VFEED_GROUP_BY_FEED')) {
-
- $reply['content'] .= "
- $feed_icon_img";
- }
-
- $reply['content'] .= "
";
- $reply['content'] .= "
";
-
- } else {
-
- if (get_pref($this->link, 'VFEED_GROUP_BY_FEED') && $line["feed_title"]) {
- if ($feed_id != $vgroup_last_feed) {
-
- $cur_feed_title = $line["feed_title"];
- $vgroup_last_feed = $feed_id;
-
- $cur_feed_title = htmlspecialchars($cur_feed_title);
-
- $vf_catchup_link = "(".__('mark as read').")";
-
- $has_feed_icon = feed_has_icon($feed_id);
-
- if ($has_feed_icon) {
- $feed_icon_img = "
";
- } else {
- //$feed_icon_img = "
";
- }
-
- $reply['content'] .= "";
- }
- }
-
- $expand_cdm = get_pref($this->link, 'CDM_EXPANDED');
-
- $mouseover_attrs = "onmouseover='postMouseIn($id)'
- onmouseout='postMouseOut($id)'";
-
- $reply['content'] .= "";
-
- $reply['content'] .= "";
-
- $reply['content'] .= "
";
-
- $reply['content'] .= "
";
-
- if ($line["orig_feed_id"]) {
-
- $tmp_result = db_query($this->link, "SELECT * FROM ttrss_archived_feeds
- WHERE id = ".$line["orig_feed_id"]);
-
- if (db_num_rows($tmp_result) != 0) {
-
- $reply['content'] .= "
";
- $reply['content'] .= __("Originally from:");
-
- $reply['content'] .= " ";
-
- $tmp_line = db_fetch_assoc($tmp_result);
-
- $reply['content'] .= "
" .
- $tmp_line['title'] . "";
-
- $reply['content'] .= " ";
-
- $reply['content'] .= "
";
- $reply['content'] .= "![".__(](images/pub_unset.svg)
";
-
- $reply['content'] .= "
";
- }
- }
-
- $feed_site_url = $line["site_url"];
-
- if ($cache_content && $line["cached_content"] != "") {
- $line["content_preview"] =& $line["cached_content"];
- }
-
- $article_content = sanitize($this->link, $line["content_preview"],
- false, false, $feed_site_url);
-
- $reply['content'] .= "
";
- if ($line['note']) {
- $reply['content'] .= format_article_note($id, $line['note']);
- }
- $reply['content'] .= "
";
-
- $reply['content'] .= "
";
- $reply['content'] .= $article_content;
- $reply['content'] .= "";
-
-/* $tmp_result = db_query($this->link, "SELECT always_display_enclosures FROM
- ttrss_feeds WHERE id = ".
- (($line['feed_id'] == null) ? $line['orig_feed_id'] :
- $line['feed_id'])." AND owner_uid = ".$_SESSION["uid"]);
-
- $always_display_enclosures = sql_bool_to_bool(db_fetch_result($tmp_result,
- 0, "always_display_enclosures")); */
-
- $always_display_enclosures = sql_bool_to_bool($line["always_display_enclosures"]);
-
- $reply['content'] .= format_article_enclosures($this->link, $id, $always_display_enclosures,
- $article_content);
-
- $reply['content'] .= "
";
-
- $reply['content'] .= "";
-
- $reply['content'] .= "
";
-
- $reply['content'] .= "
";
-
- }
-
- ++$lnum;
- }
-
- if ($_REQUEST["debug"]) $timing_info = print_checkpoint("PE", $timing_info);
-
- } else {
- $message = "";
-
- 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 < -10) {
- $message = __("No articles found to display. You can assign articles to labels manually (see the Actions menu above) or use a filter.");
- } else {
- $message = __("No articles found to display.");
- }
- }
-
- if (!$offset && $message) {
- $reply['content'] .= "$message";
-
- $reply['content'] .= "
";
-
- $result = db_query($this->link, "SELECT ".SUBSTRING_FOR_DATE."(MAX(last_updated), 1, 19) AS last_updated FROM ttrss_feeds
- WHERE owner_uid = " . $_SESSION['uid']);
-
- $last_updated = db_fetch_result($result, 0, "last_updated");
- $last_updated = make_local_datetime($this->link, $last_updated, false);
-
- $reply['content'] .= sprintf(__("Feeds last updated at %s"), $last_updated);
-
- $result = db_query($this->link, "SELECT COUNT(id) AS num_errors
- FROM ttrss_feeds WHERE last_error != '' AND owner_uid = ".$_SESSION["uid"]);
-
- $num_errors = db_fetch_result($result, 0, "num_errors");
-
- if ($num_errors > 0) {
- $reply['content'] .= "
";
- $reply['content'] .= "".
- __('Some feeds have update errors (click for details)')."";
- }
- $reply['content'] .= "
";
- }
- }
-
- 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() {
- db_query($this->link, "UPDATE ttrss_user_entries SET
- last_read = NOW(),unread = false WHERE owner_uid = " . $_SESSION["uid"]);
- ccache_zero_all($this->link, $_SESSION["uid"]);
- }
-
- function collapse() {
- $cat_id = db_escape_string($_REQUEST["cid"]);
- $mode = (int) db_escape_string($_REQUEST['mode']);
- toggle_collapse_cat($this->link, $cat_id, $mode);
- }
-
- function view() {
- $timing_info = getmicrotime();
-
- $reply = array();
-
- if ($_REQUEST["debug"]) $timing_info = print_checkpoint("0", $timing_info);
-
- $omode = db_escape_string($_REQUEST["omode"]);
-
- $feed = db_escape_string($_REQUEST["feed"]);
- $method = db_escape_string($_REQUEST["m"]);
- $view_mode = db_escape_string($_REQUEST["view_mode"]);
- $limit = (int) get_pref($this->link, "DEFAULT_ARTICLE_LIMIT");
- @$cat_view = $_REQUEST["cat"] == "true";
- @$next_unread_feed = db_escape_string($_REQUEST["nuf"]);
- @$offset = db_escape_string($_REQUEST["skip"]);
- @$vgroup_last_feed = db_escape_string($_REQUEST["vgrlf"]);
- $order_by = db_escape_string($_REQUEST["order_by"]);
-
- 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) {
- print json_encode($this->generate_dashboard_feed($this->link));
- return;
- }
-
- $result = false;
-
- if ($feed < -10) {
- $label_feed = -11-$feed;
- $result = db_query($this->link, "SELECT id FROM ttrss_labels2 WHERE
- id = '$label_feed' AND owner_uid = " . $_SESSION['uid']);
- } else if (!$cat_view && is_numeric($feed) && $feed > 0) {
- $result = db_query($this->link, "SELECT id FROM ttrss_feeds WHERE
- id = '$feed' AND owner_uid = " . $_SESSION['uid']);
- } else if ($cat_view && is_numeric($feed) && $feed > 0) {
- $result = db_query($this->link, "SELECT id FROM ttrss_feed_categories WHERE
- id = '$feed' AND owner_uid = " . $_SESSION['uid']);
- }
-
- if ($result && db_num_rows($result) == 0) {
- print json_encode($this->generate_error_feed($this->link, __("Feed not found.")));
- return;
- }
-
- /* Updating a label ccache means recalculating all of the caches
- * so for performance reasons we don't do that here */
-
- if ($feed >= 0) {
- ccache_update($this->link, $feed, $_SESSION["uid"], $cat_view);
- }
-
- set_pref($this->link, "_DEFAULT_VIEW_MODE", $view_mode);
- set_pref($this->link, "_DEFAULT_VIEW_LIMIT", $limit);
- set_pref($this->link, "_DEFAULT_VIEW_ORDER_BY", $order_by);
-
- if (!$cat_view && is_numeric($feed) && $feed > 0) {
- db_query($this->link, "UPDATE ttrss_feeds SET last_viewed = NOW()
- WHERE id = '$feed' AND owner_uid = ".$_SESSION["uid"]);
- }
-
- $reply['headlines'] = array();
-
- if (!$next_unread_feed)
- $reply['headlines']['id'] = $feed;
- else
- $reply['headlines']['id'] = $next_unread_feed;
-
- $reply['headlines']['is_cat'] = (bool) $cat_view;
-
- $override_order = false;
-
- if (get_pref($this->link, "SORT_HEADLINES_BY_FEED_DATE", $owner_uid)) {
- $date_sort_field = "updated";
- } else {
- $date_sort_field = "date_entered";
- }
-
- switch ($order_by) {
- case "date":
- if (get_pref($this->link, 'REVERSE_HEADLINES', $owner_uid)) {
- $override_order = "$date_sort_field";
- } else {
- $override_order = "$date_sort_field DESC";
- }
- break;
-
- case "title":
- if (get_pref($this->link, 'REVERSE_HEADLINES', $owner_uid)) {
- $override_order = "title DESC, $date_sort_field";
- } else {
- $override_order = "title, $date_sort_field DESC";
- }
- break;
-
- case "score":
- if (get_pref($this->link, 'REVERSE_HEADLINES', $owner_uid)) {
- $override_order = "score, $date_sort_field";
- } else {
- $override_order = "score DESC, $date_sort_field DESC";
- }
- break;
- }
-
- if ($_REQUEST["debug"]) $timing_info = print_checkpoint("04", $timing_info);
-
- $ret = $this->format_headlines_list($feed, $method,
- $view_mode, $limit, $cat_view, $next_unread_feed, $offset,
- $vgroup_last_feed, $override_order, true);
-
- $topmost_article_ids = $ret[0];
- $headlines_count = $ret[1];
- $returned_feed = $ret[2];
- $disable_cache = $ret[3];
- $vgroup_last_feed = $ret[4];
-
- $reply['headlines']['content'] =& $ret[5]['content'];
- $reply['headlines']['toolbar'] =& $ret[5]['toolbar'];
-
- 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("20", $timing_info);
-
- if (is_array($topmost_article_ids) && !get_pref($this->link, 'COMBINED_DISPLAY_MODE') && !$_SESSION["bw_limit"]) {
- $articles = array();
-
- foreach ($topmost_article_ids as $id) {
- array_push($articles, format_article($this->link, $id, false));
- }
-
- $reply['articles'] = $articles;
- }
-
- if ($_REQUEST["debug"]) $timing_info = print_checkpoint("30", $timing_info);
-
- $reply['runtime-info'] = make_runtime_info($this->link);
-
- print json_encode($reply);
-
- }
-
- private function generate_dashboard_feed($link) {
- $reply = array();
-
- $reply['headlines']['id'] = -5;
- $reply['headlines']['is_cat'] = false;
-
- $reply['headlines']['toolbar'] = '';
- $reply['headlines']['content'] = "".__('No feed selected.');
-
- $reply['headlines']['content'] .= "
";
-
- $result = db_query($link, "SELECT ".SUBSTRING_FOR_DATE."(MAX(last_updated), 1, 19) AS last_updated FROM ttrss_feeds
- WHERE owner_uid = " . $_SESSION['uid']);
-
- $last_updated = db_fetch_result($result, 0, "last_updated");
- $last_updated = make_local_datetime($link, $last_updated, false);
-
- $reply['headlines']['content'] .= sprintf(__("Feeds last updated at %s"), $last_updated);
-
- $result = db_query($link, "SELECT COUNT(id) AS num_errors
- FROM ttrss_feeds WHERE last_error != '' AND owner_uid = ".$_SESSION["uid"]);
-
- $num_errors = db_fetch_result($result, 0, "num_errors");
-
- if ($num_errors > 0) {
- $reply['headlines']['content'] .= "
";
- $reply['headlines']['content'] .= "".
- __('Some feeds have update errors (click for details)')."";
- }
- $reply['headlines']['content'] .= "
";
-
- $reply['headlines-info'] = array("count" => 0,
- "vgroup_last_feed" => '',
- "unread" => 0,
- "disable_cache" => true);
-
- return $reply;
- }
-
- private function generate_error_feed($link, $error) {
- $reply = array();
-
- $reply['headlines']['id'] = -6;
- $reply['headlines']['is_cat'] = false;
-
- $reply['headlines']['toolbar'] = '';
- $reply['headlines']['content'] = "
". $error . "
";
-
- $reply['headlines-info'] = array("count" => 0,
- "vgroup_last_feed" => '',
- "unread" => 0,
- "disable_cache" => true);
-
- return $reply;
- }
-
-
-}
-?>
+";
+ $reply .= "
";
+
+ if ($feed_site_url) {
+ $target = "target=\"_blank\"";
+ $reply .= "".
+ truncate_string($feed_title,30)."";
+
+ if ($error) {
+ $reply .= " (Error)";
+ }
+
+ } else {
+ $reply .= $feed_title;
+ }
+
+ $reply .= "";
+
+ $reply .= "
+
+ ![](\"images/pub_set.svg\")
";
+
+ $reply .= "";
+
+ // left part
+
+ $reply .= __('Select:')."
+
".__('All').",
+
".__('Unread').",
+
".__('Invert').",
+
".__('None')."";
+
+ $reply .= " ";
+
+ $reply .= "
";
+
+ //$reply .= "
";
+
+ //$reply .= " 0 && is_numeric($feed)) {
+ // Update the feed if required with some basic flood control
+
+ $result = db_query($this->link,
+ "SELECT cache_images,cache_content,".SUBSTRING_FOR_DATE."(last_updated,1,19) AS last_updated
+ FROM ttrss_feeds WHERE id = '$feed'");
+
+ if (db_num_rows($result) != 0) {
+ $last_updated = strtotime(db_fetch_result($result, 0, "last_updated"));
+ $cache_images = sql_bool_to_bool(db_fetch_result($result, 0, "cache_images"));
+ $cache_content = sql_bool_to_bool(db_fetch_result($result, 0, "cache_content"));
+
+ if (!$cache_images && !$cache_content && time() - $last_updated > 120 || isset($_REQUEST['DevForceUpdate'])) {
+ include "rssfuncs.php";
+ update_rss_feed($this->link, $feed, true, true);
+ } else {
+ db_query($this->link, "UPDATE ttrss_feeds SET last_updated = '1970-01-01', last_update_started = '1970-01-01'
+ WHERE id = '$feed'");
+ }
+ }
+ }
+
+ if ($method_split[0] == "MarkAllReadGR") {
+ catchup_feed($this->link, $method_split[1], false);
+ }
+
+ // FIXME: might break tag display?
+
+ if (is_numeric($feed) && $feed > 0 && !$cat_view) {
+ $result = db_query($this->link,
+ "SELECT id FROM ttrss_feeds WHERE id = '$feed' LIMIT 1");
+
+ if (db_num_rows($result) == 0) {
+ $reply['content'] = "".__('Feed not found.')."
";
+ }
+ }
+
+ if (is_numeric($feed) && $feed > 0) {
+
+ $result = db_query($this->link, "SELECT rtl_content FROM ttrss_feeds
+ WHERE id = '$feed' AND owner_uid = " . $_SESSION["uid"]);
+
+ if (db_num_rows($result) == 1) {
+ $rtl_content = sql_bool_to_bool(db_fetch_result($result, 0, "rtl_content"));
+ } else {
+ $rtl_content = false;
+ }
+
+ if ($rtl_content) {
+ $rtl_tag = "dir=\"RTL\"";
+ } else {
+ $rtl_tag = "";
+ }
+ } else {
+ $rtl_tag = "";
+ $rtl_content = false;
+ }
+
+ @$search = db_escape_string($_REQUEST["query"]);
+
+ if ($search) {
+ $disable_cache = true;
+ }
+
+ @$search_mode = db_escape_string($_REQUEST["search_mode"]);
+ $match_on = "both"; // deprecated, TODO: remove
+
+ if ($_REQUEST["debug"]) $timing_info = print_checkpoint("H0", $timing_info);
+
+// error_log("format_headlines_list: [" . $feed . "] method [" . $method . "]");
+ if( $search_mode == '' && $method != '' ){
+ $search_mode = $method;
+ }
+// error_log("search_mode: " . $search_mode);
+ $qfh_ret = queryFeedHeadlines($this->link, $feed, $limit, $view_mode, $cat_view,
+ $search, $search_mode, $match_on, $override_order, $offset, 0,
+ false, 0, $include_children);
+
+ if ($_REQUEST["debug"]) $timing_info = print_checkpoint("H1", $timing_info);
+
+ $result = $qfh_ret[0];
+ $feed_title = $qfh_ret[1];
+ $feed_site_url = $qfh_ret[2];
+ $last_error = $qfh_ret[3];
+ $cache_content = true;
+
+ $vgroup_last_feed = $vgr_last_feed;
+
+ $reply['toolbar'] = $this->format_headline_subtoolbar($feed_site_url,
+ $feed_title,
+ $feed, $cat_view, $search, $match_on, $search_mode, $view_mode,
+ $last_error);
+
+ $headlines_count = db_num_rows($result);
+
+ /* if (get_pref($this->link, 'COMBINED_DISPLAY_MODE')) {
+ $button_plugins = array();
+ foreach (explode(",", ARTICLE_BUTTON_PLUGINS) as $p) {
+ $pclass = "button_" . trim($p);
+
+ if (class_exists($pclass)) {
+ $plugin = new $pclass($link);
+ array_push($button_plugins, $plugin);
+ }
+ }
+ } */
+
+ global $pluginhost;
+
+ if (db_num_rows($result) > 0) {
+
+ $lnum = $offset;
+
+ $num_unread = 0;
+ $cur_feed_title = '';
+
+ $fresh_intl = get_pref($this->link, "FRESH_ARTICLE_MAX_AGE") * 60 * 60;
+
+ if ($_REQUEST["debug"]) $timing_info = print_checkpoint("PS", $timing_info);
+
+ while ($line = db_fetch_assoc($result)) {
+ $class = ($lnum % 2) ? "even" : "odd";
+
+ $id = $line["id"];
+ $feed_id = $line["feed_id"];
+ $label_cache = $line["label_cache"];
+ $labels = false;
+ $label_row_style = "";
+
+ if ($label_cache) {
+ $label_cache = json_decode($label_cache, true);
+
+ if ($label_cache) {
+ if ($label_cache["no-labels"] == 1)
+ $labels = array();
+ else
+ $labels = $label_cache;
+ }
+ }
+
+ if (!is_array($labels)) $labels = get_article_labels($this->link, $id);
+
+ if (count($labels) > 0) {
+ for ($i = 0; $i < min(4, count($labels)); $i++) {
+ $bg = rgb2hsl(_color_unpack($labels[$i][3]));
+
+ if ($bg && $bg[1] > 0) {
+ $bg[1] = 0.1;
+ $bg[2] = 1;
+
+ $bg = _color_pack(hsl2rgb($bg));
+ $label_row_style = $this->make_gradient($bg, $class);;
+
+ break;
+ }
+ }
+ }
+
+ $labels_str = "";
+ $labels_str .= format_article_labels($labels, $id);
+ $labels_str .= "";
+
+ if (count($topmost_article_ids) < 3) {
+ array_push($topmost_article_ids, $id);
+ }
+
+ if ($line["unread"] == "t" || $line["unread"] == "1") {
+ $class .= " Unread";
+ ++$num_unread;
+ $is_unread = true;
+ } else {
+ $is_unread = false;
+ }
+
+ if ($line["marked"] == "t" || $line["marked"] == "1") {
+ $marked_pic = "
link, 'images/mark_set.svg')."\"
+ class=\"markedPic\" alt=\"Unstar article\"
+ onclick='javascript:toggleMark($id)'>";
+ } else {
+ $marked_pic = "
link, 'images/mark_unset.svg')."\"
+ class=\"markedPic\" alt=\"Star article\"
+ onclick='javascript:toggleMark($id)'>";
+ }
+
+ if ($line["published"] == "t" || $line["published"] == "1") {
+ $published_pic = "
link,
+ 'images/pub_set.svg')."\"
+ class=\"markedPic\"
+ alt=\"Unpublish article\" onclick='javascript:togglePub($id)'>";
+ } else {
+ $published_pic = "
link,
+ 'images/pub_unset.svg')."\"
+ class=\"markedPic\"
+ alt=\"Publish article\" onclick='javascript:togglePub($id)'>";
+ }
+
+# $content_link = "" .
+# $line["title"] . "";
+
+# $content_link = "" .
+# $line["title"] . "";
+
+# $content_link = "" .
+# $line["title"] . "";
+
+ $updated_fmt = make_local_datetime($this->link, $line["updated_noms"], false);
+
+ if (get_pref($this->link, 'SHOW_CONTENT_PREVIEW')) {
+ $content_preview = truncate_string(strip_tags($line["content_preview"]),
+ 100);
+ }
+
+ $score = $line["score"];
+
+ $score_pic = theme_image($this->link,
+ "images/" . get_score_pic($score));
+
+/* $score_title = __("(Click to change)");
+ $score_pic = "
"; */
+
+ $score_pic = "
";
+
+ if ($score > 500) {
+ $hlc_suffix = "H";
+ } else if ($score < -100) {
+ $hlc_suffix = "L";
+ } else {
+ $hlc_suffix = "";
+ }
+
+ $entry_author = $line["author"];
+
+ if ($entry_author) {
+ $entry_author = " - $entry_author";
+ }
+
+ $has_feed_icon = feed_has_icon($feed_id);
+
+ if ($has_feed_icon) {
+ $feed_icon_img = "
";
+ } else {
+ $feed_icon_img = "
";
+ }
+
+ if (!get_pref($this->link, 'COMBINED_DISPLAY_MODE')) {
+
+ if (get_pref($this->link, 'VFEED_GROUP_BY_FEED')) {
+ if ($feed_id != $vgroup_last_feed && $line["feed_title"]) {
+
+ $cur_feed_title = $line["feed_title"];
+ $vgroup_last_feed = $feed_id;
+
+ $cur_feed_title = htmlspecialchars($cur_feed_title);
+
+ $vf_catchup_link = "(".__('mark as read').")";
+
+ $reply['content'] .= "";
+
+ }
+ }
+
+ $mouseover_attrs = "onmouseover='postMouseIn($id)'
+ onmouseout='postMouseOut($id)'";
+
+ $reply['content'] .= "";
+
+ $reply['content'] .= "
";
+
+ $reply['content'] .= "";
+
+ $reply['content'] .= "$marked_pic";
+ $reply['content'] .= "$published_pic";
+
+ $reply['content'] .= "
";
+
+ $reply['content'] .= "
";
+
+ $reply['content'] .= "
$updated_fmt";
+ $reply['content'] .= "
";
+
+ $reply['content'] .= $score_pic;
+
+ if ($line["feed_title"] && !get_pref($this->link, 'VFEED_GROUP_BY_FEED')) {
+
+ $reply['content'] .= "
+ $feed_icon_img";
+ }
+
+ $reply['content'] .= "
";
+ $reply['content'] .= "
";
+
+ } else {
+
+ if (get_pref($this->link, 'VFEED_GROUP_BY_FEED') && $line["feed_title"]) {
+ if ($feed_id != $vgroup_last_feed) {
+
+ $cur_feed_title = $line["feed_title"];
+ $vgroup_last_feed = $feed_id;
+
+ $cur_feed_title = htmlspecialchars($cur_feed_title);
+
+ $vf_catchup_link = "(".__('mark as read').")";
+
+ $has_feed_icon = feed_has_icon($feed_id);
+
+ if ($has_feed_icon) {
+ $feed_icon_img = "
";
+ } else {
+ //$feed_icon_img = "
";
+ }
+
+ $reply['content'] .= "";
+ }
+ }
+
+ $expand_cdm = get_pref($this->link, 'CDM_EXPANDED');
+
+ $mouseover_attrs = "onmouseover='postMouseIn($id)'
+ onmouseout='postMouseOut($id)'";
+
+ $reply['content'] .= "";
+
+ $reply['content'] .= "";
+
+ $reply['content'] .= "
";
+
+ $reply['content'] .= "
";
+
+ if ($line["orig_feed_id"]) {
+
+ $tmp_result = db_query($this->link, "SELECT * FROM ttrss_archived_feeds
+ WHERE id = ".$line["orig_feed_id"]);
+
+ if (db_num_rows($tmp_result) != 0) {
+
+ $reply['content'] .= "
";
+ $reply['content'] .= __("Originally from:");
+
+ $reply['content'] .= " ";
+
+ $tmp_line = db_fetch_assoc($tmp_result);
+
+ $reply['content'] .= "
" .
+ $tmp_line['title'] . "";
+
+ $reply['content'] .= " ";
+
+ $reply['content'] .= "
";
+ $reply['content'] .= "![".__(](images/pub_unset.svg)
";
+
+ $reply['content'] .= "
";
+ }
+ }
+
+ $feed_site_url = $line["site_url"];
+
+ if ($cache_content && $line["cached_content"] != "") {
+ $line["content_preview"] =& $line["cached_content"];
+ }
+
+ $article_content = sanitize($this->link, $line["content_preview"],
+ false, false, $feed_site_url);
+
+ $reply['content'] .= "
";
+ if ($line['note']) {
+ $reply['content'] .= format_article_note($id, $line['note']);
+ }
+ $reply['content'] .= "
";
+
+ $reply['content'] .= "
";
+ $reply['content'] .= $article_content;
+ $reply['content'] .= "";
+
+/* $tmp_result = db_query($this->link, "SELECT always_display_enclosures FROM
+ ttrss_feeds WHERE id = ".
+ (($line['feed_id'] == null) ? $line['orig_feed_id'] :
+ $line['feed_id'])." AND owner_uid = ".$_SESSION["uid"]);
+
+ $always_display_enclosures = sql_bool_to_bool(db_fetch_result($tmp_result,
+ 0, "always_display_enclosures")); */
+
+ $always_display_enclosures = sql_bool_to_bool($line["always_display_enclosures"]);
+
+ $reply['content'] .= format_article_enclosures($this->link, $id, $always_display_enclosures,
+ $article_content);
+
+ $reply['content'] .= "
";
+
+ $reply['content'] .= "";
+
+ $reply['content'] .= "
";
+
+ $reply['content'] .= "
";
+
+ }
+
+ ++$lnum;
+ }
+
+ if ($_REQUEST["debug"]) $timing_info = print_checkpoint("PE", $timing_info);
+
+ } else {
+ $message = "";
+
+ 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 < -10) {
+ $message = __("No articles found to display. You can assign articles to labels manually (see the Actions menu above) or use a filter.");
+ } else {
+ $message = __("No articles found to display.");
+ }
+ }
+
+ if (!$offset && $message) {
+ $reply['content'] .= "$message";
+
+ $reply['content'] .= "
";
+
+ $result = db_query($this->link, "SELECT ".SUBSTRING_FOR_DATE."(MAX(last_updated), 1, 19) AS last_updated FROM ttrss_feeds
+ WHERE owner_uid = " . $_SESSION['uid']);
+
+ $last_updated = db_fetch_result($result, 0, "last_updated");
+ $last_updated = make_local_datetime($this->link, $last_updated, false);
+
+ $reply['content'] .= sprintf(__("Feeds last updated at %s"), $last_updated);
+
+ $result = db_query($this->link, "SELECT COUNT(id) AS num_errors
+ FROM ttrss_feeds WHERE last_error != '' AND owner_uid = ".$_SESSION["uid"]);
+
+ $num_errors = db_fetch_result($result, 0, "num_errors");
+
+ if ($num_errors > 0) {
+ $reply['content'] .= "
";
+ $reply['content'] .= "".
+ __('Some feeds have update errors (click for details)')."";
+ }
+ $reply['content'] .= "
";
+ }
+ }
+
+ 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() {
+ db_query($this->link, "UPDATE ttrss_user_entries SET
+ last_read = NOW(),unread = false WHERE owner_uid = " . $_SESSION["uid"]);
+ ccache_zero_all($this->link, $_SESSION["uid"]);
+ }
+
+ function collapse() {
+ $cat_id = db_escape_string($_REQUEST["cid"]);
+ $mode = (int) db_escape_string($_REQUEST['mode']);
+ toggle_collapse_cat($this->link, $cat_id, $mode);
+ }
+
+ function view() {
+ $timing_info = getmicrotime();
+
+ $reply = array();
+
+ if ($_REQUEST["debug"]) $timing_info = print_checkpoint("0", $timing_info);
+
+ $omode = db_escape_string($_REQUEST["omode"]);
+
+ $feed = db_escape_string($_REQUEST["feed"]);
+ $method = db_escape_string($_REQUEST["m"]);
+ $view_mode = db_escape_string($_REQUEST["view_mode"]);
+ $limit = (int) get_pref($this->link, "DEFAULT_ARTICLE_LIMIT");
+ @$cat_view = $_REQUEST["cat"] == "true";
+ @$next_unread_feed = db_escape_string($_REQUEST["nuf"]);
+ @$offset = db_escape_string($_REQUEST["skip"]);
+ @$vgroup_last_feed = db_escape_string($_REQUEST["vgrlf"]);
+ $order_by = db_escape_string($_REQUEST["order_by"]);
+
+ 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) {
+ print json_encode($this->generate_dashboard_feed($this->link));
+ return;
+ }
+
+ $result = false;
+
+ if ($feed < -10) {
+ $label_feed = -11-$feed;
+ $result = db_query($this->link, "SELECT id FROM ttrss_labels2 WHERE
+ id = '$label_feed' AND owner_uid = " . $_SESSION['uid']);
+ } else if (!$cat_view && is_numeric($feed) && $feed > 0) {
+ $result = db_query($this->link, "SELECT id FROM ttrss_feeds WHERE
+ id = '$feed' AND owner_uid = " . $_SESSION['uid']);
+ } else if ($cat_view && is_numeric($feed) && $feed > 0) {
+ $result = db_query($this->link, "SELECT id FROM ttrss_feed_categories WHERE
+ id = '$feed' AND owner_uid = " . $_SESSION['uid']);
+ }
+
+ if ($result && db_num_rows($result) == 0) {
+ print json_encode($this->generate_error_feed($this->link, __("Feed not found.")));
+ return;
+ }
+
+ /* Updating a label ccache means recalculating all of the caches
+ * so for performance reasons we don't do that here */
+
+ if ($feed >= 0) {
+ ccache_update($this->link, $feed, $_SESSION["uid"], $cat_view);
+ }
+
+ set_pref($this->link, "_DEFAULT_VIEW_MODE", $view_mode);
+ set_pref($this->link, "_DEFAULT_VIEW_LIMIT", $limit);
+ set_pref($this->link, "_DEFAULT_VIEW_ORDER_BY", $order_by);
+
+ if (!$cat_view && is_numeric($feed) && $feed > 0) {
+ db_query($this->link, "UPDATE ttrss_feeds SET last_viewed = NOW()
+ WHERE id = '$feed' AND owner_uid = ".$_SESSION["uid"]);
+ }
+
+ $reply['headlines'] = array();
+
+ if (!$next_unread_feed)
+ $reply['headlines']['id'] = $feed;
+ else
+ $reply['headlines']['id'] = $next_unread_feed;
+
+ $reply['headlines']['is_cat'] = (bool) $cat_view;
+
+ $override_order = false;
+
+ if (get_pref($this->link, "SORT_HEADLINES_BY_FEED_DATE", $owner_uid)) {
+ $date_sort_field = "updated";
+ } else {
+ $date_sort_field = "date_entered";
+ }
+
+ switch ($order_by) {
+ case "date":
+ if (get_pref($this->link, 'REVERSE_HEADLINES', $owner_uid)) {
+ $override_order = "$date_sort_field";
+ } else {
+ $override_order = "$date_sort_field DESC";
+ }
+ break;
+
+ case "title":
+ if (get_pref($this->link, 'REVERSE_HEADLINES', $owner_uid)) {
+ $override_order = "title DESC, $date_sort_field";
+ } else {
+ $override_order = "title, $date_sort_field DESC";
+ }
+ break;
+
+ case "score":
+ if (get_pref($this->link, 'REVERSE_HEADLINES', $owner_uid)) {
+ $override_order = "score, $date_sort_field";
+ } else {
+ $override_order = "score DESC, $date_sort_field DESC";
+ }
+ break;
+ }
+
+ if ($_REQUEST["debug"]) $timing_info = print_checkpoint("04", $timing_info);
+
+ $ret = $this->format_headlines_list($feed, $method,
+ $view_mode, $limit, $cat_view, $next_unread_feed, $offset,
+ $vgroup_last_feed, $override_order, true);
+
+ $topmost_article_ids = $ret[0];
+ $headlines_count = $ret[1];
+ $returned_feed = $ret[2];
+ $disable_cache = $ret[3];
+ $vgroup_last_feed = $ret[4];
+
+ $reply['headlines']['content'] =& $ret[5]['content'];
+ $reply['headlines']['toolbar'] =& $ret[5]['toolbar'];
+
+ 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("20", $timing_info);
+
+ if (is_array($topmost_article_ids) && !get_pref($this->link, 'COMBINED_DISPLAY_MODE') && !$_SESSION["bw_limit"]) {
+ $articles = array();
+
+ foreach ($topmost_article_ids as $id) {
+ array_push($articles, format_article($this->link, $id, false));
+ }
+
+ $reply['articles'] = $articles;
+ }
+
+ if ($_REQUEST["debug"]) $timing_info = print_checkpoint("30", $timing_info);
+
+ $reply['runtime-info'] = make_runtime_info($this->link);
+
+ print json_encode($reply);
+
+ }
+
+ private function generate_dashboard_feed($link) {
+ $reply = array();
+
+ $reply['headlines']['id'] = -5;
+ $reply['headlines']['is_cat'] = false;
+
+ $reply['headlines']['toolbar'] = '';
+ $reply['headlines']['content'] = "".__('No feed selected.');
+
+ $reply['headlines']['content'] .= "
";
+
+ $result = db_query($link, "SELECT ".SUBSTRING_FOR_DATE."(MAX(last_updated), 1, 19) AS last_updated FROM ttrss_feeds
+ WHERE owner_uid = " . $_SESSION['uid']);
+
+ $last_updated = db_fetch_result($result, 0, "last_updated");
+ $last_updated = make_local_datetime($link, $last_updated, false);
+
+ $reply['headlines']['content'] .= sprintf(__("Feeds last updated at %s"), $last_updated);
+
+ $result = db_query($link, "SELECT COUNT(id) AS num_errors
+ FROM ttrss_feeds WHERE last_error != '' AND owner_uid = ".$_SESSION["uid"]);
+
+ $num_errors = db_fetch_result($result, 0, "num_errors");
+
+ if ($num_errors > 0) {
+ $reply['headlines']['content'] .= "
";
+ $reply['headlines']['content'] .= "".
+ __('Some feeds have update errors (click for details)')."";
+ }
+ $reply['headlines']['content'] .= "
";
+
+ $reply['headlines-info'] = array("count" => 0,
+ "vgroup_last_feed" => '',
+ "unread" => 0,
+ "disable_cache" => true);
+
+ return $reply;
+ }
+
+ private function generate_error_feed($link, $error) {
+ $reply = array();
+
+ $reply['headlines']['id'] = -6;
+ $reply['headlines']['is_cat'] = false;
+
+ $reply['headlines']['toolbar'] = '';
+ $reply['headlines']['content'] = "
". $error . "
";
+
+ $reply['headlines-info'] = array("count" => 0,
+ "vgroup_last_feed" => '',
+ "unread" => 0,
+ "disable_cache" => true);
+
+ return $reply;
+ }
+
+
+}
+?>