]> git.mxchange.org Git - quix0rs-gnu-social.git/blob - actions/disfavor.php
(dis)favor form method call fix
[quix0rs-gnu-social.git] / actions / disfavor.php
1 <?php
2 /*
3  * Laconica - a distributed open-source microblogging tool
4  * Copyright (C) 2008, Controlez-Vous, Inc.
5  *
6  * This program is free software: you can redistribute it and/or modify
7  * it under the terms of the GNU Affero General Public License as published by
8  * the Free Software Foundation, either version 3 of the License, or
9  * (at your option) any later version.
10  *
11  * This program is distributed in the hope that it will be useful,
12  * but WITHOUT ANY WARRANTY; without even the implied warranty of
13  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14  * GNU Affero General Public License for more details.
15  *
16  * You should have received a copy of the GNU Affero General Public License
17  * along with this program.  If not, see <http://www.gnu.org/licenses/>.
18  */
19
20 if (!defined('LACONICA')) { exit(1); }
21
22 require_once INSTALLDIR.'/lib/favorform.php';
23
24 class DisfavorAction extends Action
25 {
26
27     function handle($args)
28     {
29
30         parent::handle($args);
31
32         if (!common_logged_in()) {
33             $this->clientError(_('Not logged in.'));
34             return;
35         }
36
37         $user = common_current_user();
38
39         if ($_SERVER['REQUEST_METHOD'] != 'POST') {
40             common_redirect(common_local_url('showfavorites', array('nickname' => $user->nickname)));
41             return;
42         }
43
44         $id = $this->trimmed('notice');
45
46         $notice = Notice::staticGet($id);
47
48         $token = $this->trimmed('token-'.$notice->id);
49
50         if (!$token || $token != common_session_token()) {
51             $this->clientError(_("There was a problem with your session token. Try again, please."));
52             return;
53         }
54
55         $fave = new Fave();
56         $fave->user_id = $this->id;
57         $fave->notice_id = $notice->id;
58         if (!$fave->find(true)) {
59             $this->clientError(_('This notice is not a favorite!'));
60             return;
61         }
62
63         $result = $fave->delete();
64
65         if (!$result) {
66             common_log_db_error($fave, 'DELETE', __FILE__);
67             $this->serverError(_('Could not delete favorite.'));
68             return;
69         }
70         
71         $user->blowFavesCache();
72
73         if ($this->boolean('ajax')) {
74             $this->startHTML('text/xml;charset=utf-8', true);
75             $this->elementStart('head');
76             $this->element('title', null, _('Add to favorites'));
77             $this->elementEnd('head');
78             $this->elementStart('body');
79             $favor = new FavorForm($this, $notice);
80             $favor->show();
81             $this->elementEnd('body');
82             $this->elementEnd('html');
83         } else {
84             common_redirect(common_local_url('showfavorites',
85                                              array('nickname' => $user->nickname)));
86         }
87     }
88 }