aboutsummaryrefslogtreecommitdiff
path: root/app/Models/Search.php
diff options
context:
space:
mode:
Diffstat (limited to 'app/Models/Search.php')
-rw-r--r--app/Models/Search.php49
1 files changed, 49 insertions, 0 deletions
diff --git a/app/Models/Search.php b/app/Models/Search.php
index 20c4f540a..47aaa6078 100644
--- a/app/Models/Search.php
+++ b/app/Models/Search.php
@@ -14,6 +14,7 @@ class FreshRSS_Search {
private $raw_input = '';
// The following properties are extracted from the raw input
+ private $entry_ids;
private $feed_ids;
private $label_ids;
private $label_names;
@@ -27,6 +28,7 @@ class FreshRSS_Search {
private $tags;
private $search;
+ private $not_entry_ids;
private $not_feed_ids;
private $not_label_ids;
private $not_label_names;
@@ -48,6 +50,7 @@ class FreshRSS_Search {
$input = preg_replace('/:"(.*?)"/', ':"\1"', $input);
+ $input = $this->parseNotEntryIds($input);
$input = $this->parseNotFeedIds($input);
$input = $this->parseNotLabelIds($input);
$input = $this->parseNotLabelNames($input);
@@ -60,6 +63,7 @@ class FreshRSS_Search {
$input = $this->parseNotInurlSearch($input);
$input = $this->parseNotTagsSearch($input);
+ $input = $this->parseEntryIds($input);
$input = $this->parseFeedIds($input);
$input = $this->parseLabelIds($input);
$input = $this->parseLabelNames($input);
@@ -84,6 +88,13 @@ class FreshRSS_Search {
return $this->raw_input;
}
+ public function getEntryIds() {
+ return $this->entry_ids;
+ }
+ public function getNotEntryIds() {
+ return $this->not_entry_ids;
+ }
+
public function getFeedIds() {
return $this->feed_ids;
}
@@ -189,6 +200,44 @@ class FreshRSS_Search {
}
/**
+ * Parse the search string to find entry (article) IDs.
+ *
+ * @param string $input
+ * @return string
+ */
+ private function parseEntryIds($input) {
+ if (preg_match_all('/\be:(?P<search>[0-9,]*)/', $input, $matches)) {
+ $input = str_replace($matches[0], '', $input);
+ $ids_lists = $matches['search'];
+ $this->entry_ids = [];
+ foreach ($ids_lists as $ids_list) {
+ $entry_ids = explode(',', $ids_list);
+ $entry_ids = self::removeEmptyValues($entry_ids);
+ if (!empty($entry_ids)) {
+ $this->entry_ids[] = $entry_ids;
+ }
+ }
+ }
+ return $input;
+ }
+
+ private function parseNotEntryIds($input) {
+ if (preg_match_all('/[!-]e:(?P<search>[0-9,]*)/', $input, $matches)) {
+ $input = str_replace($matches[0], '', $input);
+ $ids_lists = $matches['search'];
+ $this->not_entry_ids = [];
+ foreach ($ids_lists as $ids_list) {
+ $entry_ids = explode(',', $ids_list);
+ $entry_ids = self::removeEmptyValues($entry_ids);
+ if (!empty($entry_ids)) {
+ $this->not_entry_ids[] = $entry_ids;
+ }
+ }
+ }
+ return $input;
+ }
+
+ /**
* Parse the search string to find feed IDs.
*
* @param string $input