X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=actions%2Fapidirectmessagenew.php;h=653fa3a9ed0ce88c045d996d509393a5fd64faa7;hb=cd3cff451f2ac12ebe1b98c6ab643a0e4e931599;hp=b335a9c93ee360903538f390f268ceffd648f70f;hpb=a12474a99d0322123b1c8318dfa609d5d5392c7f;p=quix0rs-gnu-social.git diff --git a/actions/apidirectmessagenew.php b/actions/apidirectmessagenew.php index b335a9c93e..653fa3a9ed 100644 --- a/actions/apidirectmessagenew.php +++ b/actions/apidirectmessagenew.php @@ -34,8 +34,6 @@ if (!defined('STATUSNET')) { exit(1); } -require_once INSTALLDIR . '/lib/apiauth.php'; - /** * Creates a new direct message from the authenticating user to * the user specified by id. @@ -51,7 +49,9 @@ require_once INSTALLDIR . '/lib/apiauth.php'; */ class ApiDirectMessageNewAction extends ApiAuthAction { - var $other = null; + protected $needPost = true; + + var $other = null; // Profile we're sending to var $content = null; /** @@ -61,28 +61,23 @@ class ApiDirectMessageNewAction extends ApiAuthAction * * @return boolean success flag */ - function prepare($args) + protected function prepare(array $args=array()) { parent::prepare($args); - $this->user = $this->auth_user; - if (empty($this->user)) { // TRANS: Client error when user not found for an API direct message action. - $this->clientError(_('No such user.'), 404, $this->format); - return; + $this->clientError(_('No such user.'), 404); } $this->content = $this->trimmed('text'); - $this->user = $this->auth_user; - $user_param = $this->trimmed('user'); $user_id = $this->arg('user_id'); $screen_name = $this->trimmed('screen_name'); if (isset($user_param) || isset($user_id) || isset($screen_name)) { - $this->other = $this->getTargetUser($user_param); + $this->other = $this->getTargetProfile($user_param); } return true; @@ -93,67 +88,38 @@ class ApiDirectMessageNewAction extends ApiAuthAction * * Save the new message * - * @param array $args $_REQUEST data (unused) - * * @return void */ - function handle($args) + protected function handle() { - parent::handle($args); - - if ($_SERVER['REQUEST_METHOD'] != 'POST') { - $this->clientError( - // TRANS: Client error. POST is a HTTP command. It should not be translated. - _('This method requires a POST.'), - 400, - $this->format - ); - return; - } + parent::handle(); if (empty($this->content)) { - $this->clientError( - // TRANS: Client error displayed when no message text was submitted (406). - _('No message text!'), - 406, - $this->format - ); + // TRANS: Client error displayed when no message text was submitted (406). + $this->clientError(_('No message text!'), 406); } else { - $content_shortened = common_shorten_links($this->content); + $content_shortened = $this->auth_user->shortenLinks($this->content); if (Message::contentTooLong($content_shortened)) { + // TRANS: Client error displayed when message content is too long. + // TRANS: %d is the maximum number of characters for a message. $this->clientError( - // TRANS: Client error displayed when message content is too long. - // TRANS: %d is the maximum number of characters for a message. - 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() - ), - 406, - $this->format - ); - return; + 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()), + 406); } } - if (empty($this->other)) { + if (!$this->other instanceof Profile) { // TRANS: Client error displayed if a recipient user could not be found (403). - $this->clientError(_('Recipient user not found.'), 403, $this->format); - return; + $this->clientError(_('Recipient user not found.'), 403); } else if (!$this->user->mutuallySubscribed($this->other)) { - $this->clientError( - // TRANS: Client error displayed trying to direct message another user who's not a friend (403). - _('Can\'t send direct messages to users who aren\'t your friend.'), - 403, - $this->format - ); - return; + // TRANS: Client error displayed trying to direct message another user who's not a friend (403). + $this->clientError(_('Cannot send direct messages to users who aren\'t your friend.'), 403); } else if ($this->user->id == $this->other->id) { // Note: sending msgs to yourself is allowed by Twitter // TRANS: Client error displayed trying to direct message self (403). - $this->clientError(_('Do not send a message to yourself; ' . - 'just say it to yourself quietly instead.'), 403, $this->format); - return; + $this->clientError(_('Do not send a message to yourself; just say it to yourself quietly instead.'), 403); } $message = Message::saveNew( @@ -163,11 +129,6 @@ class ApiDirectMessageNewAction extends ApiAuthAction $this->source ); - if (is_string($message)) { - $this->serverError($message); - return; - } - $message->notify(); if ($this->format == 'xml') {