X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=actions%2Fallrss.php;h=4b6df25048645286e97f6c12cb319d9f3e317dfe;hb=dd149a76f328ef503f6b84037c6aa56cb72a7a66;hp=885a67f6188af13b07a0ea7e6bf9a8302078e476;hpb=907b5f7b406d87c438a560e04385318662163755;p=quix0rs-gnu-social.git diff --git a/actions/allrss.php b/actions/allrss.php index 885a67f618..4b6df25048 100644 --- a/actions/allrss.php +++ b/actions/allrss.php @@ -1,19 +1,18 @@ - * @author Robin Millette + * @package StatusNet + * @author Evan Prodromou + * @author Robin Millette * @license http://www.fsf.org/licensing/licenses/agpl.html AGPLv3 - * @link http://laconi.ca/ + * @link http://status.net/ * - * Laconica - a distributed open-source microblogging tool - * Copyright (C) 2008, 2009, Control Yourself, Inc. + * StatusNet - the distributed open-source microblogging tool + * Copyright (C) 2008, 2009, StatusNet, Inc. * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as published by @@ -29,11 +28,7 @@ * along with this program. If not, see . */ -if (!defined('LACONICA')) { - exit(1); -} - -require_once INSTALLDIR.'/lib/rssaction.php'; +if (!defined('GNUSOCIAL')) { exit(1); } /** * RSS feed for user and friends timeline. @@ -41,63 +36,18 @@ require_once INSTALLDIR.'/lib/rssaction.php'; * Formatting of RSS handled by Rss10Action * * @category Action - * @package Laconica - * @author Evan Prodromou - * @author Robin Millette + * @package StatusNet + * @author Evan Prodromou + * @author Robin Millette * @license http://www.fsf.org/licensing/licenses/agpl.html AGPLv3 - * @link http://laconi.ca/ + * @link http://status.net/ */ -class AllrssAction extends Rss10Action +class AllrssAction extends TargetedRss10Action { - var $user = null; - - /** - * Initialization. - * - * @param array $args Web and URL arguments - * - * @return boolean false if user doesn't exist - */ - function prepare($args) + protected function getNotices() { - parent::prepare($args); - $nickname = $this->trimmed('nickname'); - $this->user = User::staticGet('nickname', $nickname); - - if (!$this->user) { - $this->clientError(_('No such user.')); - return false; - } else { - return true; - } - } - - /** - * Get notices - * - * @param integer $limit max number of notices to return - * - * @return array notices - */ - function getNotices($limit=0) - { - $cur = common_current_user(); - - if (!empty($cur) && $cur->id == $user->id) { - $notice = $this->user->noticeInbox(0, $limit); - } else { - $notice = $this->user->noticesWithFriends(0, $limit); - } - - $user = $this->user; - $notice = $user->noticesWithFriends(0, $limit); - $notices = array(); - - while ($notice->fetch()) { - $notices[] = clone($notice); - } - - return $notices; + $stream = new InboxNoticeStream($this->target); + return $stream->getNotices(0, $this->limit)->fetchAll(); } /** @@ -107,33 +57,17 @@ class AllrssAction extends Rss10Action */ function getChannel() { - $user = $this->user; $c = array('url' => common_local_url('allrss', array('nickname' => - $user->nickname)), - 'title' => sprintf(_('%s and friends'), $user->nickname), + $this->target->getNickname())), + // TRANS: Message is used as link title. %s is a user nickname. + 'title' => sprintf(_('%s and friends'), $this->target->getNickname()), 'link' => common_local_url('all', array('nickname' => - $user->nickname)), - 'description' => sprintf(_('Feed for friends of %s'), - $user->nickname)); + $this->target->getNickname())), + // TRANS: Message is used as link description. %1$s is a username, %2$s is a site name. + 'description' => sprintf(_('Updates from %1$s and friends on %2$s!'), + $this->target->getNickname(), common_config('site', 'name'))); return $c; } - - /** - * Get image. - * - * @return string user avatar URL or null - */ - function getImage() - { - $user = $this->user; - $profile = $user->getProfile(); - if (!$profile) { - return null; - } - $avatar = $profile->getAvatar(AVATAR_PROFILE_SIZE); - return $avatar ? $avatar->url : null; - } } -