]> git.mxchange.org Git - quix0rs-gnu-social.git/blob - actions/nudge.php
Give NoticeListItem its own class
[quix0rs-gnu-social.git] / actions / nudge.php
1 <?php
2
3 /**
4  * User by ID action class.
5  *
6  * PHP version 5
7  *
8  * @category Action
9  * @package  StatusNet
10  * @author   Evan Prodromou <evan@status.net>
11  * @author   Robin Millette <millette@status.net>
12  * @license  http://www.fsf.org/licensing/licenses/agpl.html AGPLv3
13  * @link     http://status.net/
14  *
15  * StatusNet - the distributed open-source microblogging tool
16  * Copyright (C) 2008, 2009, StatusNet, Inc.
17  *
18  * This program is free software: you can redistribute it and/or modify
19  * it under the terms of the GNU Affero General Public License as published by
20  * the Free Software Foundation, either version 3 of the License, or
21  * (at your option) any later version.
22  *
23  * This program is distributed in the hope that it will be useful,
24  * but WITHOUT ANY WARRANTY; without even the implied warranty of
25  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
26  * GNU Affero General Public License for more details.
27  *
28  * You should have received a copy of the GNU Affero General Public License
29  * along with this program.  If not, see <http://www.gnu.org/licenses/>.
30  */
31
32 if (!defined('STATUSNET') && !defined('LACONICA')) {
33     exit(1);
34 }
35
36 require_once INSTALLDIR.'/lib/mail.php';
37
38 /**
39  * Nudge a user action class.
40  *
41  * @category Action
42  * @package  StatusNet
43  * @author   Evan Prodromou <evan@status.net>
44  * @author   Robin Millette <millette@status.net>
45  * @author   Sarven Capadisli <csarven@status.net>
46  * @license  http://www.fsf.org/licensing/licenses/agpl.html AGPLv3
47  * @link     http://status.net/
48  */
49 class NudgeAction extends Action
50 {
51      /**
52      * Class handler.
53      *
54      * @param array $args array of arguments
55      *
56      * @return nothing
57      */
58     function handle($args)
59     {
60         parent::handle($args);
61
62         if (!common_logged_in()) {
63             // TRANS: Client error displayed trying to nudge a user without being logged in.
64             $this->clientError(_('Not logged in.'));
65             return;
66         }
67
68         $user  = common_current_user();
69         $other = User::staticGet('nickname', $this->arg('nickname'));
70
71         if ($_SERVER['REQUEST_METHOD'] != 'POST') {
72             common_redirect(common_local_url('showstream',
73                 array('nickname' => $other->nickname)));
74             return;
75         }
76
77         // CSRF protection
78         $token = $this->trimmed('token');
79
80         if (!$token || $token != common_session_token()) {
81             $this->clientError(_('There was a problem with your session token. Try again, please.'));
82             return;
83         }
84
85         if (!$other->email || !$other->emailnotifynudge) {
86             // TRANS: Client error displayed trying to nudge a user that cannot be nudged.
87             $this->clientError(_('This user doesn\'t allow nudges or hasn\'t confirmed or set their email address yet.'));
88             return;
89         }
90
91         $this->notify($user, $other);
92
93         if ($this->boolean('ajax')) {
94             $this->startHTML('text/xml;charset=utf-8');
95             $this->elementStart('head');
96             // TRANS: Page title after sending a nudge.
97             $this->element('title', null, _('Nudge sent'));
98             $this->elementEnd('head');
99             $this->elementStart('body');
100             // TRANS: Confirmation text after sending a nudge.
101             $this->element('p', array('id' => 'nudge_response'), _('Nudge sent!'));
102             $this->elementEnd('body');
103             $this->elementEnd('html');
104         } else {
105             // display a confirmation to the user
106             common_redirect(common_local_url('showstream',
107                                              array('nickname' => $other->nickname)),
108                             303);
109         }
110     }
111
112      /**
113      * Do the actual notification
114      *
115      * @param class $user  nudger
116      * @param class $other nudgee
117      *
118      * @return nothing
119      */
120     function notify($user, $other)
121     {
122         if ($other->id != $user->id) {
123             if ($other->email && $other->emailnotifynudge) {
124                 mail_notify_nudge($user, $other);
125             }
126             // XXX: notify by IM
127             // XXX: notify by SMS
128         }
129     }
130
131     function isReadOnly($args)
132     {
133         return true;
134     }
135 }