X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=lib%2Fprofileaction.php;h=1ba5ed77eb9abde963511aecd81d9c125bce7a3f;hb=d6b28c64830f632bb2f4b6f3c9369b9e56ad217a;hp=b2990bd249625780d369578813f66857ee357a96;hpb=9b6633698c5abda07df3102b62c37cfb0847e1ea;p=quix0rs-gnu-social.git diff --git a/lib/profileaction.php b/lib/profileaction.php index b2990bd249..1ba5ed77eb 100644 --- a/lib/profileaction.php +++ b/lib/profileaction.php @@ -28,12 +28,7 @@ * @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,65 +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 Action +abstract class ProfileAction extends ManagedAction { var $page = null; var $tag = null; protected $target = null; // Profile that we're showing - protected function prepare(array $args=array()) + protected function doPreparation() { - parent::prepare($args); - - try { - $nickname_arg = $this->arg('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); + // 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']; } - $this->user = User::getKV('nickname', $nickname); + common_redirect(common_local_url($this->getActionName(), $args), 301); + } - if (!$this->user) { - // TRANS: Client error displayed when calling a profile action without specifying a user. - $this->clientError(_('No such user.'), 404); + try { + $user = User::getByNickname($nickname); + } catch (NoSuchUserException $e) { + $group = Local_group::getKV('nickname', $nickname); + if ($group instanceof Local_group) { + common_redirect($group->getProfile()->getUrl()); } - $this->target = $this->user->getProfile(); - } catch (NicknameException $e) { - $id = (int)$this->arg('id'); - $this->target = Profile::getKV('id', $id); + // No user nor group found, throw the NoSuchUserException again + throw $e; + } - if (!($this->target instanceof Profile)) { - // TRANS: Error message displayed when referring to a user without a profile. - $this->serverError(_m('Profile ID does not exist.')); - } + $this->target = $user->getProfile(); + } - $user = User::getKV('id', $this->target->id); - if ($user instanceof User) { - // This is a local user -- send to their regular profile. - common_redirect(common_local_url('showstream', array('nickname' => $user->nickname))); - } - } + 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) && - (empty($this->scoped) || !$this->scoped->hasRight(Right::SILENCEUSER))) { + 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); } - // backwards compatibility until all actions are fixed to use $this->target - $this->profile = $this->target; - $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(array $args=array()) + { return true; } @@ -127,7 +127,7 @@ class ProfileAction extends Action 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); } @@ -141,11 +141,11 @@ class ProfileAction extends Action // TRANS: H2 text for user subscription statistics. $this->statsSectionLink('subscriptions', _('Following')); $this->text(' '); - $this->text($this->profile->subscriptionCount()); + $this->text($this->target->subscriptionCount()); $this->elementEnd('h2'); try { - $profile = $this->profile->getSubscribed(0, PROFILES_PER_MINILIST + 1); + $profile = $this->target->getSubscribed(0, PROFILES_PER_MINILIST + 1); $pml = new ProfileMiniList($profile, $this); $pml->show(); } catch (NoResultException $e) { @@ -169,11 +169,11 @@ class ProfileAction extends Action // TRANS: H2 text for user subscriber statistics. $this->statsSectionLink('subscribers', _('Followers')); $this->text(' '); - $this->text($this->profile->subscriberCount()); + $this->text($this->target->subscriberCount()); $this->elementEnd('h2'); try { - $profile = $this->profile->getSubscribers(0, PROFILES_PER_MINILIST + 1); + $profile = $this->target->getSubscribers(0, PROFILES_PER_MINILIST + 1); $sml = new SubscribersMiniList($profile, $this); $sml->show(); } catch (NoResultException $e) { @@ -189,8 +189,8 @@ class ProfileAction extends Action 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; @@ -203,20 +203,19 @@ class ProfileAction extends Action // TRANS: H2 text for user statistics. $this->element('h2', null, _('Statistics')); - $profile = $this->profile; - $actionParams = array('nickname' => $profile->nickname); + $actionParams = array('nickname' => $this->target->nickname); $stats = array( array( 'id' => 'user-id', // TRANS: Label for user statistics. 'label' => _('User ID'), - 'value' => $profile->id, + 'value' => $this->target->id, ), array( 'id' => 'member-since', // TRANS: Label for user statistics. 'label' => _('Member since'), - 'value' => date('j M Y', strtotime($profile->created)) + 'value' => date('j M Y', strtotime($this->target->created)) ), array( 'id' => 'notices', @@ -234,7 +233,7 @@ class ProfileAction extends Action ); // Give plugins a chance to add stats entries - Event::handle('ProfileStats', array($profile, &$stats)); + Event::handle('ProfileStats', array($this->target, &$stats)); foreach ($stats as $row) { $this->showStatsRow($row); @@ -258,7 +257,7 @@ class ProfileAction extends Action 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')); @@ -267,11 +266,11 @@ class ProfileAction extends Action // TRANS: H2 text for user group membership statistics. $this->statsSectionLink('usergroups', _('Groups')); $this->text(' '); - $this->text($this->profile->getGroups(0, null)->N); + $this->text($this->target->getGroupCount()); $this->elementEnd('h2'); if ($groups instanceof User_group) { - $gml = new GroupMiniList($groups, $this->profile, $this); + $gml = new GroupMiniList($groups, $this->target, $this); $cnt = $gml->show(); } else { // TRANS: Text for user user group membership statistics if user is not a member of any group. @@ -285,9 +284,7 @@ class ProfileAction extends Action function showLists() { - $cur = common_current_user(); - - $lists = $this->profile->getLists($cur); + $lists = $this->target->getLists($this->scoped); if ($lists->N > 0) { $this->elementStart('div', array('id' => 'entity_lists', @@ -296,7 +293,7 @@ class ProfileAction extends Action if (Event::handle('StartShowListsMiniList', array($this))) { $url = common_local_url('peopletagsbyuser', - array('nickname' => $this->profile->nickname)); + array('nickname' => $this->target->getNickname())); $this->elementStart('h2'); $this->element('a', @@ -317,7 +314,7 @@ class ProfileAction extends Action $url = $lists->mainpage; } else { $url = common_local_url('showprofiletag', - array('tagger' => $this->profile->nickname, + array('nickname' => $this->target->getNickname(), 'tag' => $lists->tag)); } if (!$first) { @@ -341,7 +338,7 @@ class ProfileAction extends Action class SubscribersMiniList extends ProfileMiniList { - function newListItem($profile) + function newListItem(Profile $profile) { return new SubscribersMiniListItem($profile, $this->action); }