X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=actions%2Fnewmessage.php;h=428a55762ce60b3e2b19701c0fdf7fba1f4d6151;hb=627d84a1e2db2aca5d2ce1272f6e83fb7faa8ad2;hp=350452091378203c7967b87c38cd48248f1cee9f;hpb=f6bf9529805cd58fdd1671dd9b133bde05e8ae87;p=quix0rs-gnu-social.git diff --git a/actions/newmessage.php b/actions/newmessage.php index 3504520913..428a55762c 100644 --- a/actions/newmessage.php +++ b/actions/newmessage.php @@ -25,11 +25,12 @@ * @author Zach Copley * @author Sarven Capadisli * @copyright 2008-2009 StatusNet, Inc. + * @copyright 2013 Free Software Foundation, Inc. * @license http://www.fsf.org/licensing/licenses/agpl-3.0.html GNU Affero General Public License version 3.0 * @link http://status.net/ */ -if (!defined('STATUSNET') && !defined('LACONICA')) { +if (!defined('STATUSNET')) { exit(1); } @@ -45,15 +46,8 @@ if (!defined('STATUSNET') && !defined('LACONICA')) { * @link http://status.net/ */ -class NewmessageAction extends Action +class NewmessageAction extends FormAction { - - /** - * Error message, if any - */ - - var $msg = null; - var $content = null; var $to = null; var $other = null; @@ -68,6 +62,7 @@ class NewmessageAction extends Action function title() { + // TRANS: Page title for new direct message page. return _('New message'); } @@ -79,116 +74,92 @@ class NewmessageAction extends Action * @return void */ - function handle($args) - { - parent::handle($args); - - if (!common_logged_in()) { - $this->clientError(_('Not logged in.'), 403); - } else if ($_SERVER['REQUEST_METHOD'] == 'POST') { - $this->saveNewMessage(); - } else { - $this->showForm(); - } - } - - function prepare($args) + protected function prepare(array $args=array()) { parent::prepare($args); - $user = common_current_user(); - - if (!$user) { - /* Go log in, and then come back. */ - common_set_returnto($_SERVER['REQUEST_URI']); - common_redirect(common_local_url('login')); - return false; - } - $this->content = $this->trimmed('content'); $this->to = $this->trimmed('to'); if ($this->to) { - $this->other = User::staticGet('id', $this->to); + $this->other = Profile::getKV('id', $this->to); - if (!$this->other) { + if (!$this->other instanceof Profile) { + // TRANS: Client error displayed trying to send a direct message to a non-existing user. $this->clientError(_('No such user.'), 404); - return false; } - if (!$user->mutuallySubscribed($this->other)) { - $this->clientError(_('You can\'t send a message to this user.'), 404); - return false; + if (!$this->other->isLocal()) { + // TRANS: Explains that current federation does not support direct, private messages yet. + $this->clientError(_('You cannot send direct messages to federated users yet.')); + } + + if (!$this->scoped->mutuallySubscribed($this->other)) { + // TRANS: Client error displayed trying to send a direct message to a user while sender and + // TRANS: receiver are not subscribed to each other. + $this->clientError(_('You cannot send a message to this user.'), 404); } } return true; } - function saveNewMessage() + protected function handlePost() { - // CSRF protection - - $token = $this->trimmed('token'); - if (!$token || $token != common_session_token()) { - $this->showForm(_('There was a problem with your session token. ' . - 'Try again, please.')); - return; - } + parent::handlePost(); - $user = common_current_user(); - assert($user); // XXX: maybe an error instead... + assert($this->scoped instanceof Profile); // XXX: maybe an error instead... if (!$this->content) { - $this->showForm(_('No content!')); - return; + // TRANS: Form validator error displayed trying to send a direct message without content. + $this->clientError(_('No content!')); } else { - $content_shortened = common_shorten_links($this->content); + $content_shortened = $this->scoped->shortenLinks($this->content); if (Message::contentTooLong($content_shortened)) { - $this->showForm(sprintf(_('That\'s too long. ' . - 'Max message size is %d chars.'), + // TRANS: Form validation error displayed when message content is too long. + // TRANS: %d is the maximum number of characters for a message. + $this->clientError(sprintf(_m('That\'s too long. Maximum message size is %d character.', + 'That\'s too long. Maximum message size is %d characters.', + Message::maxContent()), Message::maxContent())); - return; } } if (!$this->other) { - $this->showForm(_('No recipient specified.')); - return; - } else if (!$user->mutuallySubscribed($this->other)) { - $this->clientError(_('You can\'t send a message to this user.'), 404); - return; - } else if ($user->id == $this->other->id) { - $this->clientError(_('Don\'t send a message to yourself; ' . + // TRANS: Form validation error displayed trying to send a direct message without specifying a recipient. + $this->clientError(_('No recipient specified.')); + } else if (!$this->scoped->mutuallySubscribed($this->other)) { + // TRANS: Client error displayed trying to send a direct message to a user while sender and + // TRANS: receiver are not subscribed to each other. + $this->clientError(_('You cannot send a message to this user.'), 404); + } else if ($this->scoped->id == $this->other->id) { + // TRANS: Client error displayed trying to send a direct message to self. + $this->clientError(_('Do not send a message to yourself; ' . 'just say it to yourself quietly instead.'), 403); - return; - } - - $message = Message::saveNew($user->id, $this->other->id, $this->content, 'web'); - - if (is_string($message)) { - $this->showForm($message); - return; } + $message = Message::saveNew($this->scoped->id, $this->other->id, $this->content, 'web'); $message->notify(); if ($this->boolean('ajax')) { $this->startHTML('text/xml;charset=utf-8'); $this->elementStart('head'); + // TRANS: Page title after sending a direct message. $this->element('title', null, _('Message sent')); $this->elementEnd('head'); $this->elementStart('body'); $this->element('p', array('id' => 'command_result'), - sprintf(_('Direct message to %s sent'), + // TRANS: Confirmation text after sending a direct message. + // TRANS: %s is the direct message recipient. + sprintf(_('Direct message to %s sent.'), $this->other->nickname)); $this->elementEnd('body'); - $this->elementEnd('html'); + $this->endHTML(); } else { $url = common_local_url('outbox', - array('nickname' => $user->nickname)); + array('nickname' => $this->scoped->nickname)); common_redirect($url, 303); } } @@ -207,12 +178,13 @@ class NewmessageAction extends Action { $this->startHTML('text/xml;charset=utf-8', true); $this->elementStart('head'); + // TRANS: Page title after an AJAX error occurred on the "send direct message" page. $this->element('title', null, _('Ajax Error')); $this->elementEnd('head'); $this->elementStart('body'); $this->element('p', array('id' => 'error'), $msg); $this->elementEnd('body'); - $this->elementEnd('html'); + $this->endHTML(); } function showForm($msg = null) @@ -224,10 +196,9 @@ class NewmessageAction extends Action $this->msg = $msg; if ($this->trimmed('ajax')) { - header('Content-Type: text/xml;charset=utf-8'); - $this->xw->startDocument('1.0', 'UTF-8'); - $this->elementStart('html'); + $this->startHTML('text/xml;charset=utf-8'); $this->elementStart('head'); + // TRANS: Page title on page for sending a direct message. $this->element('title', null, _('New message')); $this->elementEnd('head'); $this->elementStart('body');