X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=actions%2Fpeopletag.php;h=dbdcf5fbc79490ee50aeb034c27cc6f52ca830fd;hb=06f19d523a381de2f782dadfd86380fa5f9cb6a6;hp=3578c53fdf0d8d7f473b79ab382ba5253768d90e;hpb=f06d5eff1028b82ebcce7753ad864dab070d6779;p=quix0rs-gnu-social.git diff --git a/actions/peopletag.php b/actions/peopletag.php index 3578c53fdf..dbdcf5fbc7 100644 --- a/actions/peopletag.php +++ b/actions/peopletag.php @@ -1,9 +1,12 @@ . + * + * @category Personal + * @package StatusNet + * @author Evan Prodromou + * @author Zach Copley + * @author Shashi Gowda + * @copyright 2009 StatusNet, Inc. + * @license http://www.fsf.org/licensing/licenses/agpl-3.0.html GNU Affero General Public License version 3.0 + * @link http://status.net/ */ -if (!defined('LACONICA')) { exit(1); } +if (!defined('STATUSNET') && !defined('LACONICA')) { + exit(1); +} -require_once INSTALLDIR.'/lib/profilelist.php'; +require_once INSTALLDIR.'/lib/peopletaglist.php'; +// cache 3 pages +define('PEOPLETAG_CACHE_WINDOW', PEOPLETAGS_PER_PAGE*3 + 1); class PeopletagAction extends Action { - - var $tag = null; var $page = null; - - function handle($args) + var $tag = null; + + function isReadOnly($args) + { + return true; + } + + function title() + { + if ($this->page == 1) { + // TRANS: Title for list page. + // TRANS: %s is a list. + return sprintf(_('Public list %s'), $this->tag); + } else { + // TRANS: Title for list page. + // TRANS: %1$s is a list, %2$d is a page number. + return sprintf(_('Public list %1$s, page %2$d'), $this->tag, $this->page); + } + } + + function prepare($args) { - parent::handle($args); - parent::prepare($args); + $this->page = ($this->arg('page')) ? ($this->arg('page')+0) : 1; - $this->tag = $this->trimmed('tag'); + $tag_arg = $this->arg('tag'); + $tag = common_canonical_tag($tag_arg); - if (!common_valid_profile_tag($this->tag)) { - $this->clientError(sprintf(_('Not a valid people tag: %s'), $this->tag)); - return; + // Permanent redirect on non-canonical nickname + + if ($tag_arg != $tag) { + $args = array('tag' => $nickname); + if ($this->page && $this->page != 1) { + $args['page'] = $this->page; + } + common_redirect(common_local_url('peopletag', $args), 301); + return false; } + $this->tag = $tag; - $this->page = $this->trimmed('page'); + return true; + } - if (!$this->page) { - $this->page = 1; - } - + function handle($args) + { + parent::handle($args); $this->showPage(); } - + + function showLocalNav() + { + $nav = new PublicGroupNav($this); + $nav->show(); + } + + function showAnonymousMessage() + { + $notice = + // TRANS: Message for anonymous users on list page. + // TRANS: This message contains Markdown links in the form [description](link). + _('Lists are how you sort similar ' . + 'people on %%site.name%%, a [micro-blogging]' . + '(http://en.wikipedia.org/wiki/Micro-blogging) service ' . + 'based on the Free Software [StatusNet](http://status.net/) tool. ' . + 'You can then easily keep track of what they ' . + 'are doing by subscribing to the list\'s timeline.' ); + $this->elementStart('div', array('id' => 'anon_notice')); + $this->raw(common_markup_to_html($notice)); + $this->elementEnd('div'); + } + function showContent() { - - $profile = new Profile(); - - $offset = ($page-1)*PROFILES_PER_PAGE; - $limit = PROFILES_PER_PAGE + 1; - - if (common_config('db','type') == 'pgsql') { - $lim = ' LIMIT ' . $limit . ' OFFSET ' . $offset; + $offset = ($this->page-1) * PEOPLETAGS_PER_PAGE; + $limit = PEOPLETAGS_PER_PAGE + 1; + + $ptags = new Profile_list(); + $ptags->tag = $this->tag; + + $user = common_current_user(); + + if (empty($user)) { + $ckey = sprintf('profile_list:tag:%s', $this->tag); + $ptags->private = false; + $ptags->orderBy('profile_list.modified DESC'); + + $c = Cache::instance(); + if ($offset+$limit <= PEOPLETAG_CACHE_WINDOW && !empty($c)) { + $cached_ptags = Profile_list::getCached($ckey, $offset, $limit); + if ($cached_ptags === false) { + $ptags->limit(0, PEOPLETAG_CACHE_WINDOW); + $ptags->find(); + + Profile_list::setCache($ckey, $ptags, $offset, $limit); + } else { + $ptags = clone($cached_ptags); + } + } else { + $ptags->limit($offset, $limit); + $ptags->find(); + } } else { - $lim = ' LIMIT ' . $offset . ', ' . $limit; + $ptags->whereAdd('(profile_list.private = false OR (' . + ' profile_list.tagger =' . $user->id . + ' AND profile_list.private = true) )'); + + $ptags->orderBy('profile_list.modified DESC'); + $ptags->find(); } - # XXX: memcached this - - $qry = 'SELECT profile.* ' . - 'FROM profile JOIN profile_tag ' . - 'ON profile.id = profile_tag.tagger ' . - 'WHERE profile_tag.tagger = profile_tag.tagged ' . - 'AND tag = "%s" ' . - 'ORDER BY profile_tag.modified DESC'; - - $profile->query(sprintf($qry, $this->tag, $lim)); - - $pl = new ProfileList($profile, null, $this); + $pl = new PeopletagList($ptags, $this); $cnt = $pl->show(); - - $this->pagination($this->page > 1, - $cnt > PROFILES_PER_PAGE, - $this->page, - $this->trimmed('action'), - array('tag' => $this->tag)); + + $this->pagination($this->page > 1, $cnt > PEOPLETAGS_PER_PAGE, + $this->page, 'peopletag', array('tag' => $this->tag)); } - - function title() + + function showSections() { - return sprintf( _('Users self-tagged with %s - page %d'), $this->tag, $this->page); } - }