X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=lib%2Fprofileaction.php;h=bdcd575b6b6b946cb5fa2ce2390960b4b60cd0f9;hb=5a2d7601770a13f8cdb31285f271397ecf675be1;hp=cd3f5bcde5b94b2bf6b3fc86bb0f60998685da1b;hpb=4d61760154a53e39d1e0499d5fe7a4a586e7a9f0;p=quix0rs-gnu-social.git diff --git a/lib/profileaction.php b/lib/profileaction.php index cd3f5bcde5..bdcd575b6b 100644 --- a/lib/profileaction.php +++ b/lib/profileaction.php @@ -23,17 +23,12 @@ * @package StatusNet * @author Evan Prodromou * @author Sarven Capadisli - * @copyright 2008-2009 StatusNet, Inc. + * @copyright 2008-2011 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('STATUSNET') && !defined('LACONICA')) { - exit(1); -} - -require_once INSTALLDIR.'/lib/profileminilist.php'; -require_once INSTALLDIR.'/lib/groupminilist.php'; +if (!defined('GNUSOCIAL')) { exit(1); } /** * Profile action common superclass @@ -46,49 +41,70 @@ require_once INSTALLDIR.'/lib/groupminilist.php'; * @license http://www.fsf.org/licensing/licenses/agpl-3.0.html GNU Affero General Public License version 3.0 * @link http://status.net/ */ -class ProfileAction extends OwnerDesignAction +abstract class ProfileAction extends ManagedAction { var $page = null; - var $profile = null; var $tag = null; - function prepare($args) - { - parent::prepare($args); + protected $target = null; // Profile that we're showing - $nickname_arg = $this->arg('nickname'); + protected function doPreparation() + { + // showstream requires a nickname + $nickname_arg = $this->trimmed('nickname'); $nickname = common_canonical_nickname($nickname_arg); // Permanent redirect on non-canonical nickname - if ($nickname_arg != $nickname) { $args = array('nickname' => $nickname); if ($this->arg('page') && $this->arg('page') != 1) { $args['page'] = $this->arg['page']; } - common_redirect(common_local_url($this->trimmed('action'), $args), 301); - return false; + common_redirect(common_local_url($this->getActionName(), $args), 301); } - $this->user = User::staticGet('nickname', $nickname); + try { + $user = User::getByNickname($nickname); + } catch (NoSuchUserException $e) { + $group = Local_group::getKV('nickname', $nickname); + if ($group instanceof Local_group) { + common_redirect($group->getProfile()->getUrl()); + } - if (!$this->user) { - // TRANS: Client error displayed when calling a profile action without specifying a user. - $this->clientError(_('No such user.'), 404); - return false; + // No user nor group found, throw the NoSuchUserException again + throw $e; } - $this->profile = $this->user->getProfile(); + $this->target = $user->getProfile(); + } - if (!$this->profile) { - // TRANS: Server error displayed when calling a profile action while the specified user does not have a profile. - $this->serverError(_('User has no profile.')); - return false; + protected function prepare(array $args=array()) + { + // this will call ->doPreparation() which child classes use to set $this->target + parent::prepare($args); + + if ($this->target->hasRole(Profile_role::SILENCED) + && (!$this->scoped instanceof Profile || !$this->scoped->hasRight(Right::SILENCEUSER))) { + throw new ClientException(_('This profile has been silenced by site moderators'), 403); } $this->tag = $this->trimmed('tag'); $this->page = ($this->arg('page')) ? ($this->arg('page')+0) : 1; common_set_returnto($this->selfUrl()); + + return true; + } + + public function getTarget() + { + if (!$this->target instanceof Profile) { + throw new ServerException('No target profile in ProfileAction class'); + } + return $this->target; + } + + function isReadOnly($args) + { return true; } @@ -97,8 +113,7 @@ class ProfileAction extends OwnerDesignAction $this->showSubscriptions(); $this->showSubscribers(); $this->showGroups(); - $this->showPeopletagSubs(); - $this->showPeopletags(); + $this->showLists(); $this->showStatistics(); } @@ -112,39 +127,30 @@ class ProfileAction extends OwnerDesignAction private function statsSectionLink($actionClass, $title, $cssClass='') { $this->element('a', array('href' => common_local_url($actionClass, - array('nickname' => $this->profile->nickname)), + array('nickname' => $this->target->getNickname())), 'class' => $cssClass), $title); } function showSubscriptions() { - $profile = $this->profile->getSubscriptions(0, PROFILES_PER_MINILIST + 1); - $this->elementStart('div', array('id' => 'entity_subscriptions', 'class' => 'section')); if (Event::handle('StartShowSubscriptionsMiniList', array($this))) { $this->elementStart('h2'); // TRANS: H2 text for user subscription statistics. - $this->statsSectionLink('subscriptions', _('Subscriptions')); + $this->statsSectionLink('subscriptions', _('Following')); + $this->text(' '); + $this->text($this->target->subscriptionCount()); $this->elementEnd('h2'); - - $cnt = 0; - - if (!empty($profile)) { + + try { + $profile = $this->target->getSubscribed(0, PROFILES_PER_MINILIST + 1); $pml = new ProfileMiniList($profile, $this); - $cnt = $pml->show(); - if ($cnt == 0) { - // TRANS: Text for user subscription statistics if the user has no subscriptions. - $this->element('p', null, _('(None)')); - } - } - - if ($cnt > PROFILES_PER_MINILIST) { - $this->elementStart('p'); - // TRANS: Text for user subscription statistics if user has more subscriptions than displayed. - $this->statsSectionLink('subscriptions', _('All subscriptions'), 'more'); - $this->elementEnd('p'); + $pml->show(); + } catch (NoResultException $e) { + // TRANS: Text for user subscription statistics if the user has no subscription + $this->element('p', null, _('(None)')); } Event::handle('EndShowSubscriptionsMiniList', array($this)); @@ -154,8 +160,6 @@ class ProfileAction extends OwnerDesignAction function showSubscribers() { - $profile = $this->profile->getSubscribers(0, PROFILES_PER_MINILIST + 1); - $this->elementStart('div', array('id' => 'entity_subscribers', 'class' => 'section')); @@ -163,25 +167,18 @@ class ProfileAction extends OwnerDesignAction $this->elementStart('h2'); // TRANS: H2 text for user subscriber statistics. - $this->statsSectionLink('subscribers', _('Subscribers')); + $this->statsSectionLink('subscribers', _('Followers')); + $this->text(' '); + $this->text($this->target->subscriberCount()); $this->elementEnd('h2'); - $cnt = 0; - - if (!empty($profile)) { + try { + $profile = $this->target->getSubscribers(0, PROFILES_PER_MINILIST + 1); $sml = new SubscribersMiniList($profile, $this); - $cnt = $sml->show(); - if ($cnt == 0) { - // TRANS: Text for user subscriber statistics if user has no subscribers. - $this->element('p', null, _('(None)')); - } - } - - if ($cnt > PROFILES_PER_MINILIST) { - $this->elementStart('p'); - // TRANS: Text for user subscription statistics if user has more subscribers than displayed. - $this->statsSectionLink('subscribers', _('All subscribers'), 'more'); - $this->elementEnd('p'); + $sml->show(); + } catch (NoResultException $e) { + // TRANS: Text for user subscriber statistics if user has no subscribers. + $this->element('p', null, _('(None)')); } Event::handle('EndShowSubscribersMiniList', array($this)); @@ -190,36 +187,10 @@ class ProfileAction extends OwnerDesignAction $this->elementEnd('div'); } - function showPeopletagSubs() - { - $user = common_current_user(); - if (!empty($user) && $this->profile->id == $user->id) { - if (Event::handle('StartShowPeopletagSubscriptionsSection', array($this))) { - - $profile = $user->getProfile(); - $section = new PeopletagSubscriptionsSection($this, $profile); - $section->show(); - - Event::handle('EndShowPeopletagSubscriptionsSection', array($this)); - } - } - } - - function showPeopletags() - { - if (Event::handle('StartShowPeopletagsSection', array($this))) { - - $section = new PeopletagsForUserSection($this, $this->profile); - $section->show(); - - Event::handle('EndShowPeopletagsSection', array($this)); - } - } - function showStatistics() { - $notice_count = $this->profile->noticeCount(); - $age_days = (time() - strtotime($this->profile->created)) / 86400; + $notice_count = $this->target->noticeCount(); + $age_days = (time() - strtotime($this->target->created)) / 86400; if ($age_days < 1) { // Rather than extrapolating out to a bajillion... $age_days = 1; @@ -232,7 +203,7 @@ class ProfileAction extends OwnerDesignAction // TRANS: H2 text for user statistics. $this->element('h2', null, _('Statistics')); - $profile = $this->profile; + $profile = $this->target; $actionParams = array('nickname' => $profile->nickname); $stats = array( array( @@ -247,27 +218,6 @@ class ProfileAction extends OwnerDesignAction 'label' => _('Member since'), 'value' => date('j M Y', strtotime($profile->created)) ), - array( - 'id' => 'subscriptions', - // TRANS: Label for user statistics. - 'label' => _('Subscriptions'), - 'link' => common_local_url('subscriptions', $actionParams), - 'value' => $profile->subscriptionCount(), - ), - array( - 'id' => 'subscribers', - // TRANS: Label for user statistics. - 'label' => _('Subscribers'), - 'link' => common_local_url('subscribers', $actionParams), - 'value' => $profile->subscriberCount(), - ), - array( - 'id' => 'groups', - // TRANS: Label for user statistics. - 'label' => _('Groups'), - 'link' => common_local_url('usergroups', $actionParams), - 'value' => $profile->getGroups()->N, - ), array( 'id' => 'notices', // TRANS: Label for user statistics. @@ -308,7 +258,7 @@ class ProfileAction extends OwnerDesignAction function showGroups() { - $groups = $this->profile->getGroups(0, GROUPS_PER_MINILIST + 1); + $groups = $this->target->getGroups(0, GROUPS_PER_MINILIST + 1); $this->elementStart('div', array('id' => 'entity_groups', 'class' => 'section')); @@ -316,28 +266,75 @@ class ProfileAction extends OwnerDesignAction $this->elementStart('h2'); // TRANS: H2 text for user group membership statistics. $this->statsSectionLink('usergroups', _('Groups')); + $this->text(' '); + $this->text($this->target->getGroupCount()); $this->elementEnd('h2'); - if ($groups) { - $gml = new GroupMiniList($groups, $this->profile, $this); + if ($groups instanceof User_group) { + $gml = new GroupMiniList($groups, $this->target, $this); $cnt = $gml->show(); - if ($cnt == 0) { - // TRANS: Text for user user group membership statistics if user is not a member of any group. - $this->element('p', null, _('(None)')); - } - } - - if ($cnt > GROUPS_PER_MINILIST) { - $this->elementStart('p'); - // TRANS: Text for user group membership statistics if user has more subscriptions than displayed. - $this->statsSectionLink('usergroups', _('All groups'), 'more'); - $this->elementEnd('p'); + } else { + // TRANS: Text for user user group membership statistics if user is not a member of any group. + $this->element('p', null, _('(None)')); } Event::handle('EndShowGroupsMiniList', array($this)); } $this->elementEnd('div'); } + + function showLists() + { + $lists = $this->target->getLists($this->scoped); + + if ($lists->N > 0) { + $this->elementStart('div', array('id' => 'entity_lists', + 'class' => 'section')); + + if (Event::handle('StartShowListsMiniList', array($this))) { + + $url = common_local_url('peopletagsbyuser', + array('nickname' => $this->target->getNickname())); + + $this->elementStart('h2'); + $this->element('a', + array('href' => $url), + // TRANS: H2 text for user list membership statistics. + _('Lists')); + $this->text(' '); + $this->text($lists->N); + $this->elementEnd('h2'); + + $this->elementStart('ul'); + + + $first = true; + + while ($lists->fetch()) { + if (!empty($lists->mainpage)) { + $url = $lists->mainpage; + } else { + $url = common_local_url('showprofiletag', + array('nickname' => $this->target->getNickname(), + 'tag' => $lists->tag)); + } + if (!$first) { + $this->text(', '); + } else { + $first = false; + } + + $this->element('a', array('href' => $url), + $lists->tag); + } + + $this->elementEnd('ul'); + + Event::handle('EndShowListsMiniList', array($this)); + } + $this->elementEnd('div'); + } + } } class SubscribersMiniList extends ProfileMiniList