X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=actions%2Fuserrss.php;h=b7078fcaf886a2967a11cc3d2b058b89cf6f37c2;hb=e475bdfe772607a21c689f51553f9c40e5c7338f;hp=a3e5a3aab710a05699ef64eeffb5c6084397d35a;hpb=8e0508dad3bb888b0c01834614b1aa7e16cfe583;p=quix0rs-gnu-social.git diff --git a/actions/userrss.php b/actions/userrss.php index a3e5a3aab7..b7078fcaf8 100644 --- a/actions/userrss.php +++ b/actions/userrss.php @@ -1,7 +1,7 @@ . */ -if (!defined('LACONICA')) { exit(1); } +if (!defined('STATUSNET') && !defined('LACONICA')) { exit(1); } require_once(INSTALLDIR.'/lib/rssaction.php'); @@ -25,34 +25,57 @@ require_once(INSTALLDIR.'/lib/rssaction.php'); class UserrssAction extends Rss10Action { - - var $user = null; + var $tag = null; function prepare($args) { + common_debug("UserrssAction"); + parent::prepare($args); - $nickname = $this->trimmed('nickname'); + $nickname = $this->trimmed('nickname'); $this->user = User::staticGet('nickname', $nickname); + $this->tag = $this->trimmed('tag'); if (!$this->user) { $this->clientError(_('No such user.')); return false; } else { + if (!empty($this->tag)) { + $this->notices = $this->getTaggedNotices(); + } else { + $this->notices = $this->getNotices(); + } return true; } } - function getNotices($limit=0) + function getTaggedNotices() { + $notice = $this->user->getTaggedNotices( + $this->tag, + 0, + ($this->limit == 0) ? NOTICES_PER_PAGE : $this->limit, + 0, + 0 + ); + + $notices = array(); + while ($notice->fetch()) { + $notices[] = clone($notice); + } - $user = $this->user; + return $notices; + } - if (is_null($user)) { - return null; - } - $notice = $user->getNotices(0, ($limit == 0) ? NOTICES_PER_PAGE : $limit); + function getNotices() + { + $notice = $this->user->getNotices( + 0, + ($this->limit == 0) ? NOTICES_PER_PAGE : $this->limit + ); + $notices = array(); while ($notice->fetch()) { $notices[] = clone($notice); } @@ -67,9 +90,12 @@ class UserrssAction extends Rss10Action $c = array('url' => common_local_url('userrss', array('nickname' => $user->nickname)), - 'title' => $user->nickname, + // TRANS: Message is used as link title. %s is a user nickname. + 'title' => sprintf(_('%s timeline'), $user->nickname), 'link' => $profile->profileurl, - 'description' => sprintf(_('Microblog by %s'), $user->nickname)); + // TRANS: Message is used as link description. %1$s is a username, %2$s is a site name. + 'description' => sprintf(_('Updates from %1$s on %2$s!'), + $user->nickname, common_config('site', 'name'))); return $c; } @@ -79,7 +105,7 @@ class UserrssAction extends Rss10Action $profile = $user->getProfile(); if (!$profile) { common_log_db_error($user, 'SELECT', __FILE__); - $this->serverError(_('User without matching profile')); + $this->serverError(_('User without matching profile.')); return null; } $avatar = $profile->getAvatar(AVATAR_PROFILE_SIZE); @@ -95,7 +121,7 @@ class UserrssAction extends Rss10Action parent::initRss($limit); } - function isReadOnly() + function isReadOnly($args) { return true; }