2 class Article extends Protected_Handler {
\r
4 function csrf_ignore($method) {
\r
5 $csrf_ignored = array("redirect");
\r
7 return array_search($method, $csrf_ignored) !== false;
\r
10 function redirect() {
\r
11 $id = db_escape_string($_REQUEST['id']);
\r
13 $result = db_query($this->link, "SELECT link FROM ttrss_entries, ttrss_user_entries
\r
14 WHERE id = '$id' AND id = ref_id AND owner_uid = '".$_SESSION['uid']."'
\r
17 if (db_num_rows($result) == 1) {
\r
18 $article_url = db_fetch_result($result, 0, 'link');
\r
19 $article_url = str_replace("\n", "", $article_url);
\r
21 header("Location: $article_url");
\r
25 print_error(__("Article not found."));
\r
30 $id = db_escape_string($_REQUEST["id"]);
\r
31 $cids = explode(",", db_escape_string($_REQUEST["cids"]));
\r
32 $mode = db_escape_string($_REQUEST["mode"]);
\r
33 $omode = db_escape_string($_REQUEST["omode"]);
\r
35 // in prefetch mode we only output requested cids, main article
\r
36 // just gets marked as read (it already exists in client cache)
\r
38 $articles = array();
\r
41 array_push($articles, format_article($this->link, $id, false));
\r
42 } else if ($mode == "zoom") {
\r
43 array_push($articles, format_article($this->link, $id, true, true));
\r
44 } else if ($mode == "raw") {
\r
45 if ($_REQUEST['html']) {
\r
46 header("Content-Type: text/html");
\r
47 print '<link rel="stylesheet" type="text/css" href="tt-rss.css"/>';
\r
50 $article = format_article($this->link, $id, false);
\r
51 print $article['content'];
\r
55 catchupArticleById($this->link, $id, 0);
\r
57 if (!$_SESSION["bw_limit"]) {
\r
58 foreach ($cids as $cid) {
\r
60 array_push($articles, format_article($this->link, $cid, false, false));
\r
65 print json_encode($articles);
\r