From c939dfc39645f6fd687dd926c50286eda4b2c2df Mon Sep 17 00:00:00 2001 From: Andrew Dolgov Date: Mon, 13 Jul 2015 12:40:56 +0300 Subject: [PATCH] rework filter preview to use native regexp implementation --- classes/pref/filters.php | 112 +++++++++++++++++++++++++++------------ 1 file changed, 79 insertions(+), 33 deletions(-) diff --git a/classes/pref/filters.php b/classes/pref/filters.php index 170c1a52..6e8f4630 100644 --- a/classes/pref/filters.php +++ b/classes/pref/filters.php @@ -54,6 +54,7 @@ class Pref_Filters extends Handler_Protected { checkbox_to_sql_bool($this->dbh->escape_string($_REQUEST["inverse"]))); $filter["rules"] = array(); + $filter["actions"] = array("dummy-action"); $result = $this->dbh->query("SELECT id,name FROM ttrss_filter_types"); @@ -62,6 +63,8 @@ class Pref_Filters extends Handler_Protected { $filter_types[$line["id"]] = $line["name"]; } + $scope_qparts = array(); + $rctr = 0; foreach ($_REQUEST["rule"] AS $r) { $rule = json_decode($r, true); @@ -75,6 +78,14 @@ class Pref_Filters extends Handler_Protected { unset($rule["feed_id"]); } + if (isset($rule["feed_id"])) { + array_push($scope_qparts, "feed_id = " . $rule["feed_id"]); + } + + if (isset($rule["cat_id"])) { + array_push($scope_qparts, "cat_id = " . $rule["feed_id"]); + } + array_push($filter["rules"], $rule); ++$rctr; @@ -83,59 +94,94 @@ class Pref_Filters extends Handler_Protected { } } - $qfh_ret = queryFeedHeadlines(-4, 30, "", false, false, false, - "date_entered DESC", 0, $_SESSION["uid"], $filter); - - $result = $qfh_ret[0]; - $found = 0; + $offset = 0; + $limit = 30; + $started = time(); print __("Articles matching this filter:"); + require_once "include/rssfuncs.php"; + print "
"; print ""; - while ($line = $this->dbh->fetch_assoc($result)) { - $line["content_preview"] = truncate_string(strip_tags($line["content"]), 100, '...'); + $glue = $filter['match_any_rule'] ? " AND " : "OR "; + $scope_qpart = join($glue, $scope_qparts); - foreach (PluginHost::getInstance()->get_hooks(PluginHost::HOOK_QUERY_HEADLINES) as $p) { - $line = $p->hook_query_headlines($line, 100); - } + while ($found < $limit && $offset < $limit * 10 && time() - $started < ini_get("max_execution_time") * 0.7) { - $content_preview = $line["content_preview"]; + $result = db_query("SELECT ttrss_entries.id, + ttrss_entries.title, + ttrss_feeds.id AS feed_id, + ttrss_feed_categories.id AS cat_id, + content, + link, + author, + tag_cache + FROM + ttrss_entries, ttrss_user_entries + LEFT JOIN ttrss_feeds ON (feed_id = ttrss_feeds.id) + LEFT JOIN ttrss_feed_categories ON (ttrss_feeds.cat_id = ttrss_feed_categories.id) + WHERE + ref_id = ttrss_entries.id AND + ($scope_qpart) AND + ttrss_user_entries.owner_uid = " . $_SESSION["uid"] . " + ORDER BY date_entered DESC LIMIT $limit OFFSET $offset"); - if ($line["feed_title"]) - $feed_title = $line["feed_title"]; + while ($line = db_fetch_assoc($result)) { - print ""; + $rc = get_article_filters(array($filter), $line['title'], $line['content'], $line['link'], + false, $line['author'], explode(",", $line['tag_cache'])); - print ""; - print ""; + foreach (PluginHost::getInstance()->get_hooks(PluginHost::HOOK_QUERY_HEADLINES) as $p) { + $line = $p->hook_query_headlines($line, 100); + } - $found++; - } + $content_preview = $line["content_preview"]; - if ($found == 0) { - print ""; + + print ""; + print ""; - print ""; + $found++; + } + } + + $offset += $limit; + } + if ($found == 0) { + print "
"; + if (count($rc) > 0) { - print $line["title"]; - print " ("; - print "" . $feed_title . ""; - print "): "; - print "" . $content_preview . ""; - print " " . mb_substr($line["date_entered"], 0, 16); + $line["content_preview"] = truncate_string(strip_tags($line["content"]), 100, '...'); - print "
" . - __("No recent articles matching this filter have been found."); + if ($line["feed_title"]) $feed_title = $line["feed_title"]; + + print "
"; + + foreach ($filter['rules'] as $rule) { + $reg_exp = $rule['reg_exp']; + $reg_exp = str_replace('/', '\/', $rule["reg_exp"]); + + $line["title"] = preg_replace("/($reg_exp)/i", + "$1", $line["title"]); + + $content_preview = preg_replace("/($reg_exp)/i", + "$1", $content_preview); + } - print "
"; + print $line["title"]; + print " ("; + print "" . $feed_title . ""; + print "): "; + print "" . $content_preview . ""; + print " " . mb_substr($line["date_entered"], 0, 16); - print __("Complex expressions might not give results while testing due to issues with database server regexp implementation."); + print "
" . + __("No recent articles matching this filter have been found."); } print "
"; -- 2.39.2