X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=actions%2Ftag.php;h=751e8dcec52e92ef65c5a5bdce6ba4ce1159109b;hb=4238875ebe784dfcac2d639ef48cae005923f86d;hp=045fac97b52286e1f9839f607ea15ced53840d76;hpb=5a2bab07b25443eacc7f5cfde4b9932cdb511e92;p=quix0rs-gnu-social.git diff --git a/actions/tag.php b/actions/tag.php index 045fac97b5..751e8dcec5 100644 --- a/actions/tag.php +++ b/actions/tag.php @@ -17,50 +17,46 @@ * along with this program. If not, see . */ -if (!defined('STATUSNET') && !defined('LACONICA')) { exit(1); } +if (!defined('GNUSOCIAL')) { exit(1); } // @todo FIXME: documentation missing. -class TagAction extends Action +class TagAction extends ManagedAction { var $notice; + var $tag; + var $page; - function prepare($args) + protected function prepare(array $args=array()) { parent::prepare($args); + $taginput = $this->trimmed('tag'); $this->tag = common_canonical_tag($taginput); - if (!$this->tag) { + if (empty($this->tag)) { common_redirect(common_local_url('publictagcloud'), 301); - return false; } - if ($this->tag != $taginput) { - common_redirect(common_local_url('tag', array('tag' => $this->tag)), - 301); - return false; + // after common_canonical_tag we have a lowercase, no-specials tag string + if ($this->tag !== $taginput) { + common_redirect(common_local_url('tag', array('tag' => $this->tag)), 301); } $this->page = ($this->arg('page')) ? ($this->arg('page')+0) : 1; common_set_returnto($this->selfUrl()); - $this->notice = Notice_tag::getStream($this->tag, (($this->page-1)*NOTICES_PER_PAGE), NOTICES_PER_PAGE + 1); + $this->notice = Notice_tag::getStream($this->tag)->getNotices(($this->page-1)*NOTICES_PER_PAGE, + NOTICES_PER_PAGE + 1); if($this->page > 1 && $this->notice->N == 0){ - // TRANS: Server error when page not found (404). - $this->serverError(_('No such page.'),$code=404); + // TRANS: Client error when page not found (404). + $this->clientError(_('No such page.'), 404); } return true; } - function showSections() - { - $pop = new PopularNoticeSection($this); - $pop->show(); - } - function title() { if ($this->page == 1) { @@ -76,16 +72,17 @@ class TagAction extends Action } } - function handle($args) - { - parent::handle($args); - - $this->showPage(); - } - function getFeeds() { - return array(new Feed(Feed::RSS1, + return array(new Feed(Feed::JSON, + common_local_url('ApiTimelineTag', + array('format' => 'as', + 'tag' => $this->tag)), + // TRANS: Link label for feed on "notices with tag" page. + // TRANS: %s is the tag the feed is for. + sprintf(_('Notice feed for tag %s (Activity Streams JSON)'), + $this->tag)), + new Feed(Feed::RSS1, common_local_url('tagrss', array('tag' => $this->tag)), // TRANS: Link label for feed on "notices with tag" page. @@ -110,11 +107,11 @@ class TagAction extends Action $this->tag))); } - function showContent() + protected function showContent() { if(Event::handle('StartTagShowContent', array($this))) { - $nl = new NoticeList($this->notice, $this); + $nl = new PrimaryNoticeList($this->notice, $this, array('show_n'=>NOTICES_PER_PAGE)); $cnt = $nl->show();