summaryrefslogtreecommitdiff
path: root/classes/pref/filters.php
diff options
context:
space:
mode:
authorAndrew Dolgov <[email protected]>2015-07-13 12:40:56 +0300
committerAndrew Dolgov <[email protected]>2015-07-13 12:40:56 +0300
commitc939dfc39645f6fd687dd926c50286eda4b2c2df (patch)
tree2eaf442cd3b5abc1d3a2f5be8690c03762a6bc2b /classes/pref/filters.php
parentb8887ebb14cb8d27d385e3e4db965dbc46473732 (diff)
rework filter preview to use native regexp implementation
Diffstat (limited to 'classes/pref/filters.php')
-rw-r--r--classes/pref/filters.php112
1 files changed, 79 insertions, 33 deletions
diff --git a/classes/pref/filters.php b/classes/pref/filters.php
index 170c1a527..6e8f4630c 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 "<div class=\"filterTestHolder\">";
print "<table width=\"100%\" cellspacing=\"0\" id=\"prefErrorFeedList\">";
- 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 "<tr>";
+ $rc = get_article_filters(array($filter), $line['title'], $line['content'], $line['link'],
+ false, $line['author'], explode(",", $line['tag_cache']));
- print "<td width='5%' align='center'><input
- dojoType=\"dijit.form.CheckBox\" checked=\"1\"
- disabled=\"1\" type=\"checkbox\"></td>";
- print "<td>";
+ if (count($rc) > 0) {
- print $line["title"];
- print "&nbsp;(";
- print "<b>" . $feed_title . "</b>";
- print "):&nbsp;";
- print "<span class=\"insensitive\">" . $content_preview . "</span>";
- print " " . mb_substr($line["date_entered"], 0, 16);
+ $line["content_preview"] = truncate_string(strip_tags($line["content"]), 100, '...');
- print "</td></tr>";
+ 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 "<tr><td align='center'>" .
- __("No recent articles matching this filter have been found.");
+ if ($line["feed_title"]) $feed_title = $line["feed_title"];
+
+ print "<tr>";
+
+ print "<td width='5%' align='center'><input dojoType=\"dijit.form.CheckBox\"
+ checked=\"1\" disabled=\"1\" type=\"checkbox\"></td>";
+ print "<td>";
+
+ foreach ($filter['rules'] as $rule) {
+ $reg_exp = $rule['reg_exp'];
+ $reg_exp = str_replace('/', '\/', $rule["reg_exp"]);
+
+ $line["title"] = preg_replace("/($reg_exp)/i",
+ "<span class=\"highlight\">$1</span>", $line["title"]);
+
+ $content_preview = preg_replace("/($reg_exp)/i",
+ "<span class=\"highlight\">$1</span>", $content_preview);
+ }
- print "</td></tr><tr><td class='insensitive' align='center'>";
+ print $line["title"];
+ print "&nbsp;(";
+ print "<b>" . $feed_title . "</b>";
+ print "):&nbsp;";
+ print "<span class=\"insensitive\">" . $content_preview . "</span>";
+ 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 "</td></tr>";
- print "</td></tr>";
+ $found++;
+ }
+ }
+
+ $offset += $limit;
+ }
+ if ($found == 0) {
+ print "<tr><td align='center'>" .
+ __("No recent articles matching this filter have been found.");
}
print "</table></div>";