]> git.mxchange.org Git - quix0rs-gnu-social.git/blobdiff - lib/tagnoticestream.php
Use ToSelector choice again.
[quix0rs-gnu-social.git] / lib / tagnoticestream.php
index 567f04b7e45c56ba8866da522e11a9e4656b1f78..28f5d0e82483ab4536b4427c07002f0c80e00e12 100644 (file)
  * @link      http://status.net/
  */
 
-if (!defined('STATUSNET')) {
-    // This check helps protect against security problems;
-    // your code file can't be executed directly from the web.
-    exit(1);
-}
+if (!defined('GNUSOCIAL')) { exit(1); }
 
 /**
  * Stream of notices with a given tag
@@ -89,7 +85,23 @@ class RawTagNoticeStream extends NoticeStream
         Notice::addWhereSinceId($nt, $since_id, 'notice_id');
         Notice::addWhereMaxId($nt, $max_id, 'notice_id');
 
-        $nt->orderBy('created DESC, notice_id DESC');
+        if (!empty($this->selectVerbs)) {
+            $nt->joinAdd(array('notice_id', 'notice:id'));
+
+            $filter = array_keys(array_filter($this->selectVerbs));
+            if (!empty($filter)) {
+                // include verbs in selectVerbs with values that equate to true
+                $nt->whereAddIn('notice.verb', $filter, 'string');
+            }
+
+            $filter = array_keys(array_filter($this->selectVerbs, function ($v) { return !$v; }));
+            if (!empty($filter)) {
+                // exclude verbs in selectVerbs with values that equate to false
+                $nt->whereAddIn('!notice.verb', $filter, 'string');
+            }
+        }
+
+        $nt->orderBy('notice.created DESC, notice_id DESC');
 
         if (!is_null($offset)) {
             $nt->limit($offset, $limit);