"selectForUser" and "" selectFirstForUser" is now moved to Post
[friendica.git/.git] / src / Module / Starred.php
1 <?php
2 /**
3  * @copyright Copyright (C) 2020, Friendica
4  *
5  * @license GNU AGPL version 3 or any later version
6  *
7  * This program is free software: you can redistribute it and/or modify
8  * it under the terms of the GNU Affero General Public License as
9  * published by the Free Software Foundation, either version 3 of the
10  * License, or (at your option) any later version.
11  *
12  * This program is distributed in the hope that it will be useful,
13  * but WITHOUT ANY WARRANTY; without even the implied warranty of
14  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
15  * GNU Affero General Public License for more details.
16  *
17  * You should have received a copy of the GNU Affero General Public License
18  * along with this program.  If not, see <https://www.gnu.org/licenses/>.
19  *
20  */
21
22 namespace Friendica\Module;
23
24 use Friendica\BaseModule;
25 use Friendica\DI;
26 use Friendica\Model\Item;
27 use Friendica\Model\Post;
28
29 /**
30  * Toggle starred items
31  */
32 class Starred extends BaseModule
33 {
34         public static function rawContent(array $parameters = [])
35         {
36                 if (!local_user()) {
37                         throw new \Friendica\Network\HTTPException\ForbiddenException();
38                 }
39
40                 if (empty($parameters['item'])) {
41                         throw new \Friendica\Network\HTTPException\BadRequestException();
42                 }
43
44                 $itemId = intval($parameters['item']);
45
46                 $item = Post::selectFirstForUser(local_user(), ['starred'], ['uid' => local_user(), 'id' => $itemId]);
47                 if (empty($item)) {
48                         throw new \Friendica\Network\HTTPException\NotFoundException();
49                 }
50
51                 $starred = !(bool)$item['starred'];
52
53                 Item::update(['starred' => $starred], ['id' => $itemId]);
54
55                 // See if we've been passed a return path to redirect to
56                 $returnPath = $_REQUEST['return'] ?? '';
57                 if (!empty($returnPath)) {
58                         $rand = '_=' . time() . (strpos($returnPath, '?') ? '&' : '?') . 'rand';
59                         DI::baseUrl()->redirect($returnPath . $rand);
60                 }
61
62                 // the json doesn't really matter, it will either be 0 or 1
63                 echo json_encode((int)$starred);
64                 exit();
65         }
66 }