X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=plugins%2FFavorite%2Factions%2Fapifavoritecreate.php;h=7ff8f391b2466309df4d109866c1e16df438cf49;hb=d6b28c64830f632bb2f4b6f3c9369b9e56ad217a;hp=00c1e21bbf7b169f81459edc8de264935017c7c9;hpb=7e597ea7cc85c3b7c7226d443b21fb3252c8fd7e;p=quix0rs-gnu-social.git diff --git a/plugins/Favorite/actions/apifavoritecreate.php b/plugins/Favorite/actions/apifavoritecreate.php index 00c1e21bbf..7ff8f391b2 100644 --- a/plugins/Favorite/actions/apifavoritecreate.php +++ b/plugins/Favorite/actions/apifavoritecreate.php @@ -24,15 +24,14 @@ * @author Craig Andrews * @author Evan Prodromou * @author Zach Copley + * @author Mikael Nordfeldth * @copyright 2009 StatusNet, Inc. * @copyright 2009 Free Software Foundation, Inc http://www.fsf.org * @license http://www.fsf.org/licensing/licenses/agpl-3.0.html GNU Affero General Public License version 3.0 - * @link http://status.net/ + * @link http://gnu.io/ */ -if (!defined('STATUSNET')) { - exit(1); -} +if (!defined('GNUSOCIAL')) { exit(1); } /** * Favorites the status specified in the ID parameter as the authenticating user. @@ -43,29 +42,29 @@ if (!defined('STATUSNET')) { * @author Craig Andrews * @author Evan Prodromou * @author Zach Copley + * @author Mikael Nordfeldth * @license http://www.fsf.org/licensing/licenses/agpl-3.0.html GNU Affero General Public License version 3.0 - * @link http://status.net/ + * @link http://gnu.io/ */ class ApiFavoriteCreateAction extends ApiAuthAction { var $notice = null; + protected $needPost = true; + /** * Take arguments for running * - * @param array $args $_REQUEST args - * * @return boolean success flag */ - function prepare($args) + protected function prepare(array $args=array()) { parent::prepare($args); - $this->user = $this->auth_user; $this->notice = Notice::getKV($this->arg('id')); - if ($this->notice->repeat_of != '' ) { - common_log(LOG_DEBUG, 'Trying to Fave '.$this->notice->id.', repeat of '.$this->notice->repeat_of); - common_log(LOG_DEBUG, 'Will Fave '.$this->notice->repeat_of.' instead'); + if (!empty($this->notice->repeat_of)) { + common_debug('Trying to Fave '.$this->notice->id.', repeat of '.$this->notice->repeat_of); + common_debug('Will Fave '.$this->notice->repeat_of.' instead'); $real_notice_id = $this->notice->repeat_of; $this->notice = Notice::getKV($real_notice_id); } @@ -78,23 +77,11 @@ class ApiFavoriteCreateAction extends ApiAuthAction * * Check the format and show the user info * - * @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 (!in_array($this->format, array('xml', 'json'))) { $this->clientError( @@ -103,7 +90,6 @@ class ApiFavoriteCreateAction extends ApiAuthAction 404, $this->format ); - return; } if (empty($this->notice)) { @@ -113,61 +99,19 @@ class ApiFavoriteCreateAction extends ApiAuthAction 404, $this->format ); - return; } - // Note: Twitter lets you fave things repeatedly via API. - - if (Fave::existsForProfile($this->notice, $this->scoped)) { - $this->clientError( - // TRANS: Client error displayed when trying to mark a notice favourite that already is a favourite. - _('This status is already a favorite.'), - 403, - $this->format - ); - return; + try { + $stored = Fave::addNew($this->scoped, $this->notice); + } catch (AlreadyFulfilledException $e) { + // Note: Twitter lets you fave things repeatedly via API. + $this->clientError($e->getMessage(), 403); } - $fave = Fave::addNew($this->user->getProfile(), $this->notice); - - if (empty($fave)) { - $this->clientError( - // TRANS: Client error displayed when marking a notice as favourite fails. - _('Could not create favorite.'), - 403, - $this->format - ); - return; - } - - $this->notify($fave, $this->notice, $this->user); - Fave::blowCacheForProfileId($this->user->id); - if ($this->format == 'xml') { $this->showSingleXmlStatus($this->notice); } elseif ($this->format == 'json') { $this->show_single_json_status($this->notice); } } - - /** - * Notify the author of the favorite that the user likes their notice - * - * @param Favorite $fave the favorite in question - * @param Notice $notice the notice that's been faved - * @param User $user the user doing the favoriting - * - * @return void - */ - function notify($fave, $notice, $user) - { - $other = User::getKV('id', $notice->profile_id); - if ($other && $other->id != $user->id) { - if ($other->email && $other->emailnotifyfav) { - mail_notify_fave($other, $user, $notice); - } - // XXX: notify by IM - // XXX: notify by SMS - } - } }