]> git.mxchange.org Git - friendica.git/blobdiff - mod/starred.php
Update use statement lists with new Friendica\Database\dba class
[friendica.git] / mod / starred.php
index 035b81e764c26494cdab26239e1fa1897e078ec0..443308c27729962b50ce41554527e15f53820672 100644 (file)
@@ -1,33 +1,50 @@
 <?php
-
-
-function starred_init(&$a) {
-
+/**
+ * @file mod/starred.php
+ */
+use Friendica\App;
+use Friendica\Core\System;
+use Friendica\Database\DBM;
+use Friendica\Model\Item;
+
+function starred_init(App $a) {
        $starred = 0;
+       $message_id = null;
 
-       if(! local_user())
+       if (!local_user()) {
                killme();
-       if($a->argc > 1)
+       }
+       if ($a->argc > 1) {
                $message_id = intval($a->argv[1]);
-       if(! $message_id)
+       }
+       if (!$message_id) {
                killme();
+       }
 
-       $r = q("SELECT starred FROM item WHERE uid = %d AND id = %d LIMIT 1",
-               intval(local_user()),
-               intval($message_id)
-       );
-       if(! count($r))
+       $item = Item::selectFirstForUser(local_user(), ['starred'], ['uid' => local_user(), 'id' => $message_id]);
+       if (!DBM::is_result($item)) {
                killme();
+       }
 
-       if(! intval($r[0]['starred']))
+       if (!intval($item['starred'])) {
                $starred = 1;
+       }
+
+       Item::update(['starred' => $starred], ['id' => $message_id]);
+
+       // See if we've been passed a return path to redirect to
+       $return_path = (x($_REQUEST,'return') ? $_REQUEST['return'] : '');
+       if ($return_path) {
+               $rand = '_=' . time();
+               if (strpos($return_path, '?')) {
+                       $rand = "&$rand";
+               } else {
+                       $rand = "?$rand";
+               }
+
+               goaway(System::baseUrl() . "/" . $return_path . $rand);
+       }
 
-       $r = q("UPDATE item SET starred = %d WHERE uid = %d and id = %d LIMIT 1",
-               intval($starred),
-               intval(local_user()),
-               intval($message_id)
-       );
        // the json doesn't really matter, it will either be 0 or 1
 
        echo json_encode($starred);