86f6880d505e10e43b0ba4160daa34030fbd44aa
[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
28 /**
29  * Toggle starred items
30  */
31 class Starred extends BaseModule
32 {
33         public static function rawContent(array $parameters = [])
34         {
35                 if (!local_user()) {
36                         throw new \Friendica\Network\HTTPException\ForbiddenException();
37                 }
38
39                 if (empty($parameters['item'])) {
40                         throw new \Friendica\Network\HTTPException\BadRequestException();
41                 }
42
43                 $itemId = intval($parameters['item']);
44
45                 $item = Item::selectFirstForUser(local_user(), ['starred'], ['uid' => local_user(), 'id' => $itemId]);
46                 if (empty($item)) {
47                         throw new \Friendica\Network\HTTPException\NotFoundException();
48                 }
49
50                 $starred = !(bool)$item['starred'];
51
52                 Item::update(['starred' => $starred], ['id' => $itemId]);
53
54                 // See if we've been passed a return path to redirect to
55                 $returnPath = $_REQUEST['return'] ?? '';
56                 if (!empty($returnPath)) {
57                         $rand = '_=' . time() . (strpos($returnPath, '?') ? '&' : '?') . 'rand';
58                         DI::baseUrl()->redirect($returnPath . $rand);
59                 }
60
61                 // the json doesn't really matter, it will either be 0 or 1
62                 echo json_encode((int)$starred);
63                 exit();
64         }
65 }