2009-04-08 06:47:08 +09:00
|
|
|
<?php
|
|
|
|
/**
|
2009-08-26 07:12:20 +09:00
|
|
|
* StatusNet, the distributed open-source microblogging tool
|
2009-04-08 06:47:08 +09:00
|
|
|
*
|
|
|
|
* Common parent of Personal and Profile actions
|
|
|
|
*
|
|
|
|
* PHP version 5
|
|
|
|
*
|
|
|
|
* LICENCE: This program is free software: you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU Affero General Public License as published by
|
|
|
|
* the Free Software Foundation, either version 3 of the License, or
|
|
|
|
* (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU Affero General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU Affero General Public License
|
|
|
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
*
|
|
|
|
* @category Personal
|
2009-08-26 07:12:20 +09:00
|
|
|
* @package StatusNet
|
2009-08-26 07:19:04 +09:00
|
|
|
* @author Evan Prodromou <evan@status.net>
|
|
|
|
* @author Sarven Capadisli <csarven@status.net>
|
2011-06-10 05:20:19 +09:00
|
|
|
* @copyright 2008-2011 StatusNet, Inc.
|
2009-04-08 06:47:08 +09:00
|
|
|
* @license http://www.fsf.org/licensing/licenses/agpl-3.0.html GNU Affero General Public License version 3.0
|
2009-08-26 07:16:46 +09:00
|
|
|
* @link http://status.net/
|
2009-04-08 06:47:08 +09:00
|
|
|
*/
|
|
|
|
|
2015-04-23 04:22:02 +09:00
|
|
|
if (!defined('GNUSOCIAL')) { exit(1); }
|
2009-04-08 06:47:08 +09:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Profile action common superclass
|
|
|
|
*
|
|
|
|
* Abstracts out common code from profile and personal tabs
|
|
|
|
*
|
|
|
|
* @category Personal
|
2009-08-26 07:12:20 +09:00
|
|
|
* @package StatusNet
|
2009-08-26 07:19:04 +09:00
|
|
|
* @author Evan Prodromou <evan@status.net>
|
2009-04-08 06:47:08 +09:00
|
|
|
* @license http://www.fsf.org/licensing/licenses/agpl-3.0.html GNU Affero General Public License version 3.0
|
2009-08-26 07:16:46 +09:00
|
|
|
* @link http://status.net/
|
2009-04-08 06:47:08 +09:00
|
|
|
*/
|
2015-07-05 02:48:35 +09:00
|
|
|
abstract class ProfileAction extends ManagedAction
|
2009-04-08 06:47:08 +09:00
|
|
|
{
|
2009-05-19 06:18:57 +09:00
|
|
|
var $page = null;
|
|
|
|
var $tag = null;
|
2009-04-08 06:47:08 +09:00
|
|
|
|
2013-10-09 04:08:02 +09:00
|
|
|
protected $target = null; // Profile that we're showing
|
|
|
|
|
2015-06-06 04:24:41 +09:00
|
|
|
protected function prepare(array $args=array())
|
2009-04-08 06:47:08 +09:00
|
|
|
{
|
2015-06-26 03:13:27 +09:00
|
|
|
// this will call ->doPreparation() which child classes use to set $this->target
|
2015-06-06 04:24:41 +09:00
|
|
|
parent::prepare($args);
|
2009-04-08 06:47:08 +09:00
|
|
|
|
2015-06-06 04:24:41 +09:00
|
|
|
if ($this->target->hasRole(Profile_role::SILENCED)
|
|
|
|
&& (!$this->scoped instanceof Profile || !$this->scoped->hasRight(Right::SILENCEUSER))) {
|
2012-03-08 21:45:56 +09:00
|
|
|
throw new ClientException(_('This profile has been silenced by site moderators'), 403);
|
|
|
|
}
|
|
|
|
|
2009-05-19 06:18:57 +09:00
|
|
|
$this->tag = $this->trimmed('tag');
|
2009-04-08 06:47:08 +09:00
|
|
|
$this->page = ($this->arg('page')) ? ($this->arg('page')+0) : 1;
|
|
|
|
common_set_returnto($this->selfUrl());
|
2015-04-23 04:22:02 +09:00
|
|
|
|
2015-06-06 04:24:41 +09:00
|
|
|
return true;
|
2009-04-08 06:47:08 +09:00
|
|
|
}
|
|
|
|
|
2015-06-06 04:49:34 +09:00
|
|
|
protected function profileActionPreparation()
|
|
|
|
{
|
|
|
|
// Nothing to do by default.
|
|
|
|
}
|
|
|
|
|
2015-06-06 04:30:50 +09:00
|
|
|
public function getTarget()
|
|
|
|
{
|
2015-07-10 20:44:47 +09:00
|
|
|
if (!$this->target instanceof Profile) {
|
|
|
|
throw new ServerException('No target profile in ProfileAction class');
|
|
|
|
}
|
2015-06-06 04:30:50 +09:00
|
|
|
return $this->target;
|
|
|
|
}
|
|
|
|
|
2014-05-13 05:41:05 +09:00
|
|
|
function isReadOnly($args)
|
|
|
|
{
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2009-04-08 06:47:08 +09:00
|
|
|
function showSections()
|
|
|
|
{
|
|
|
|
$this->showSubscriptions();
|
|
|
|
$this->showSubscribers();
|
|
|
|
$this->showGroups();
|
2011-04-15 05:57:50 +09:00
|
|
|
$this->showLists();
|
2009-04-08 06:47:08 +09:00
|
|
|
$this->showStatistics();
|
|
|
|
}
|
|
|
|
|
2011-01-19 05:52:38 +09:00
|
|
|
/**
|
|
|
|
* Convenience function for common pattern of links to subscription/groups sections.
|
|
|
|
*
|
|
|
|
* @param string $actionClass
|
|
|
|
* @param string $title
|
|
|
|
* @param string $cssClass
|
|
|
|
*/
|
|
|
|
private function statsSectionLink($actionClass, $title, $cssClass='')
|
|
|
|
{
|
|
|
|
$this->element('a', array('href' => common_local_url($actionClass,
|
2014-05-13 05:41:05 +09:00
|
|
|
array('nickname' => $this->target->getNickname())),
|
2011-01-19 05:52:38 +09:00
|
|
|
'class' => $cssClass),
|
|
|
|
$title);
|
|
|
|
}
|
|
|
|
|
2009-04-08 06:47:08 +09:00
|
|
|
function showSubscriptions()
|
|
|
|
{
|
|
|
|
$this->elementStart('div', array('id' => 'entity_subscriptions',
|
|
|
|
'class' => 'section'));
|
2010-03-04 01:14:39 +09:00
|
|
|
if (Event::handle('StartShowSubscriptionsMiniList', array($this))) {
|
2011-01-19 05:52:38 +09:00
|
|
|
$this->elementStart('h2');
|
2011-01-29 08:33:13 +09:00
|
|
|
// TRANS: H2 text for user subscription statistics.
|
2011-04-15 05:08:10 +09:00
|
|
|
$this->statsSectionLink('subscriptions', _('Following'));
|
|
|
|
$this->text(' ');
|
2014-05-13 05:41:05 +09:00
|
|
|
$this->text($this->target->subscriptionCount());
|
2011-01-19 05:52:38 +09:00
|
|
|
$this->elementEnd('h2');
|
2013-09-26 07:47:56 +09:00
|
|
|
|
|
|
|
try {
|
2014-05-13 05:41:05 +09:00
|
|
|
$profile = $this->target->getSubscribed(0, PROFILES_PER_MINILIST + 1);
|
2010-03-04 01:14:39 +09:00
|
|
|
$pml = new ProfileMiniList($profile, $this);
|
2013-09-26 07:47:56 +09:00
|
|
|
$pml->show();
|
|
|
|
} catch (NoResultException $e) {
|
|
|
|
// TRANS: Text for user subscription statistics if the user has no subscription
|
|
|
|
$this->element('p', null, _('(None)'));
|
2009-04-08 06:47:08 +09:00
|
|
|
}
|
|
|
|
|
2010-03-04 01:14:39 +09:00
|
|
|
Event::handle('EndShowSubscriptionsMiniList', array($this));
|
|
|
|
}
|
2009-04-08 06:47:08 +09:00
|
|
|
$this->elementEnd('div');
|
|
|
|
}
|
|
|
|
|
|
|
|
function showSubscribers()
|
|
|
|
{
|
|
|
|
$this->elementStart('div', array('id' => 'entity_subscribers',
|
|
|
|
'class' => 'section'));
|
|
|
|
|
2010-04-05 23:12:40 +09:00
|
|
|
if (Event::handle('StartShowSubscribersMiniList', array($this))) {
|
2009-04-08 06:47:08 +09:00
|
|
|
|
2011-01-19 05:52:38 +09:00
|
|
|
$this->elementStart('h2');
|
2011-01-29 08:33:13 +09:00
|
|
|
// TRANS: H2 text for user subscriber statistics.
|
2011-04-15 05:08:10 +09:00
|
|
|
$this->statsSectionLink('subscribers', _('Followers'));
|
|
|
|
$this->text(' ');
|
2014-05-13 05:41:05 +09:00
|
|
|
$this->text($this->target->subscriberCount());
|
2011-01-19 05:52:38 +09:00
|
|
|
$this->elementEnd('h2');
|
2009-07-02 10:40:14 +09:00
|
|
|
|
2013-09-26 07:47:56 +09:00
|
|
|
try {
|
2014-05-13 05:41:05 +09:00
|
|
|
$profile = $this->target->getSubscribers(0, PROFILES_PER_MINILIST + 1);
|
2010-04-05 23:22:54 +09:00
|
|
|
$sml = new SubscribersMiniList($profile, $this);
|
2013-09-26 07:47:56 +09:00
|
|
|
$sml->show();
|
|
|
|
} catch (NoResultException $e) {
|
|
|
|
// TRANS: Text for user subscriber statistics if user has no subscribers.
|
|
|
|
$this->element('p', null, _('(None)'));
|
2009-04-08 06:47:08 +09:00
|
|
|
}
|
|
|
|
|
2010-04-05 23:12:40 +09:00
|
|
|
Event::handle('EndShowSubscribersMiniList', array($this));
|
2009-04-08 06:47:08 +09:00
|
|
|
}
|
|
|
|
|
|
|
|
$this->elementEnd('div');
|
|
|
|
}
|
|
|
|
|
|
|
|
function showStatistics()
|
|
|
|
{
|
2014-05-13 05:41:05 +09:00
|
|
|
$notice_count = $this->target->noticeCount();
|
|
|
|
$age_days = (time() - strtotime($this->target->created)) / 86400;
|
2010-03-24 03:25:36 +09:00
|
|
|
if ($age_days < 1) {
|
|
|
|
// Rather than extrapolating out to a bajillion...
|
|
|
|
$age_days = 1;
|
|
|
|
}
|
|
|
|
$daily_count = round($notice_count / $age_days);
|
2009-04-08 06:47:08 +09:00
|
|
|
|
|
|
|
$this->elementStart('div', array('id' => 'entity_statistics',
|
|
|
|
'class' => 'section'));
|
|
|
|
|
2011-01-29 08:33:13 +09:00
|
|
|
// TRANS: H2 text for user statistics.
|
2009-04-08 06:47:08 +09:00
|
|
|
$this->element('h2', null, _('Statistics'));
|
|
|
|
|
2014-05-13 05:41:05 +09:00
|
|
|
$profile = $this->target;
|
2011-01-19 06:21:59 +09:00
|
|
|
$actionParams = array('nickname' => $profile->nickname);
|
|
|
|
$stats = array(
|
|
|
|
array(
|
|
|
|
'id' => 'user-id',
|
2011-01-29 08:33:13 +09:00
|
|
|
// TRANS: Label for user statistics.
|
2011-01-19 06:21:59 +09:00
|
|
|
'label' => _('User ID'),
|
|
|
|
'value' => $profile->id,
|
|
|
|
),
|
|
|
|
array(
|
|
|
|
'id' => 'member-since',
|
2011-01-29 08:33:13 +09:00
|
|
|
// TRANS: Label for user statistics.
|
2011-01-19 06:21:59 +09:00
|
|
|
'label' => _('Member since'),
|
|
|
|
'value' => date('j M Y', strtotime($profile->created))
|
|
|
|
),
|
|
|
|
array(
|
|
|
|
'id' => 'notices',
|
2011-01-29 08:33:13 +09:00
|
|
|
// TRANS: Label for user statistics.
|
2011-01-19 06:21:59 +09:00
|
|
|
'label' => _('Notices'),
|
|
|
|
'value' => $notice_count,
|
|
|
|
),
|
|
|
|
array(
|
|
|
|
'id' => 'daily_notices',
|
2011-01-29 08:33:13 +09:00
|
|
|
// TRANS: Label for user statistics.
|
|
|
|
// TRANS: Average count of posts made per day since account registration.
|
2011-01-19 06:21:59 +09:00
|
|
|
'label' => _('Daily average'),
|
|
|
|
'value' => $daily_count
|
|
|
|
)
|
|
|
|
);
|
|
|
|
|
|
|
|
// Give plugins a chance to add stats entries
|
|
|
|
Event::handle('ProfileStats', array($profile, &$stats));
|
|
|
|
|
|
|
|
foreach ($stats as $row) {
|
|
|
|
$this->showStatsRow($row);
|
|
|
|
}
|
2009-04-08 06:47:08 +09:00
|
|
|
$this->elementEnd('div');
|
|
|
|
}
|
|
|
|
|
2011-01-19 06:21:59 +09:00
|
|
|
private function showStatsRow($row)
|
2011-01-19 06:12:08 +09:00
|
|
|
{
|
2011-01-19 06:21:59 +09:00
|
|
|
$this->elementStart('dl', 'entity_' . $row['id']);
|
2011-01-19 06:12:08 +09:00
|
|
|
$this->elementStart('dt');
|
2011-01-19 06:21:59 +09:00
|
|
|
if (!empty($row['link'])) {
|
|
|
|
$this->element('a', array('href' => $row['link']), $row['label']);
|
2011-01-19 06:12:08 +09:00
|
|
|
} else {
|
2011-01-19 06:21:59 +09:00
|
|
|
$this->text($row['label']);
|
2011-01-19 06:12:08 +09:00
|
|
|
}
|
|
|
|
$this->elementEnd('dt');
|
2011-01-19 06:21:59 +09:00
|
|
|
$this->element('dd', null, $row['value']);
|
2011-01-19 06:12:08 +09:00
|
|
|
$this->elementEnd('dl');
|
|
|
|
}
|
|
|
|
|
2009-04-08 06:47:08 +09:00
|
|
|
function showGroups()
|
|
|
|
{
|
2014-05-13 05:41:05 +09:00
|
|
|
$groups = $this->target->getGroups(0, GROUPS_PER_MINILIST + 1);
|
2009-04-08 06:47:08 +09:00
|
|
|
|
|
|
|
$this->elementStart('div', array('id' => 'entity_groups',
|
|
|
|
'class' => 'section'));
|
2010-03-04 02:55:01 +09:00
|
|
|
if (Event::handle('StartShowGroupsMiniList', array($this))) {
|
2011-01-19 05:52:38 +09:00
|
|
|
$this->elementStart('h2');
|
2011-01-29 08:33:13 +09:00
|
|
|
// TRANS: H2 text for user group membership statistics.
|
2011-01-19 05:52:38 +09:00
|
|
|
$this->statsSectionLink('usergroups', _('Groups'));
|
2011-04-15 05:08:10 +09:00
|
|
|
$this->text(' ');
|
2014-05-13 05:41:05 +09:00
|
|
|
$this->text($this->target->getGroupCount());
|
2011-01-19 05:52:38 +09:00
|
|
|
$this->elementEnd('h2');
|
2009-04-08 06:47:08 +09:00
|
|
|
|
2013-10-29 19:27:26 +09:00
|
|
|
if ($groups instanceof User_group) {
|
2014-05-13 05:41:05 +09:00
|
|
|
$gml = new GroupMiniList($groups, $this->target, $this);
|
2010-03-04 02:55:01 +09:00
|
|
|
$cnt = $gml->show();
|
2013-10-29 19:27:26 +09:00
|
|
|
} else {
|
|
|
|
// TRANS: Text for user user group membership statistics if user is not a member of any group.
|
|
|
|
$this->element('p', null, _('(None)'));
|
2010-03-04 02:55:01 +09:00
|
|
|
}
|
2009-04-08 06:47:08 +09:00
|
|
|
|
2010-03-04 02:55:01 +09:00
|
|
|
Event::handle('EndShowGroupsMiniList', array($this));
|
2009-04-08 06:47:08 +09:00
|
|
|
}
|
2010-03-04 02:55:01 +09:00
|
|
|
$this->elementEnd('div');
|
2009-04-08 06:47:08 +09:00
|
|
|
}
|
2011-04-15 05:57:50 +09:00
|
|
|
|
|
|
|
function showLists()
|
|
|
|
{
|
2014-05-13 05:41:05 +09:00
|
|
|
$lists = $this->target->getLists($this->scoped);
|
2011-04-15 05:57:50 +09:00
|
|
|
|
|
|
|
if ($lists->N > 0) {
|
|
|
|
$this->elementStart('div', array('id' => 'entity_lists',
|
|
|
|
'class' => 'section'));
|
|
|
|
|
|
|
|
if (Event::handle('StartShowListsMiniList', array($this))) {
|
|
|
|
|
2011-04-15 06:27:26 +09:00
|
|
|
$url = common_local_url('peopletagsbyuser',
|
2014-05-13 05:41:05 +09:00
|
|
|
array('nickname' => $this->target->getNickname()));
|
2011-04-15 06:27:26 +09:00
|
|
|
|
2011-04-15 05:57:50 +09:00
|
|
|
$this->elementStart('h2');
|
2011-04-15 06:27:26 +09:00
|
|
|
$this->element('a',
|
|
|
|
array('href' => $url),
|
2011-04-15 22:07:35 +09:00
|
|
|
// TRANS: H2 text for user list membership statistics.
|
2011-04-15 06:27:26 +09:00
|
|
|
_('Lists'));
|
2011-04-15 05:57:50 +09:00
|
|
|
$this->text(' ');
|
|
|
|
$this->text($lists->N);
|
|
|
|
$this->elementEnd('h2');
|
|
|
|
|
|
|
|
$this->elementStart('ul');
|
|
|
|
|
|
|
|
|
2011-04-15 06:03:10 +09:00
|
|
|
$first = true;
|
|
|
|
|
2011-04-15 05:57:50 +09:00
|
|
|
while ($lists->fetch()) {
|
2011-04-15 06:27:26 +09:00
|
|
|
if (!empty($lists->mainpage)) {
|
|
|
|
$url = $lists->mainpage;
|
|
|
|
} else {
|
|
|
|
$url = common_local_url('showprofiletag',
|
2014-05-13 05:41:05 +09:00
|
|
|
array('tagger' => $this->target->getNickname(),
|
2011-04-15 06:27:26 +09:00
|
|
|
'tag' => $lists->tag));
|
2011-04-15 05:57:50 +09:00
|
|
|
}
|
2011-04-15 06:27:26 +09:00
|
|
|
if (!$first) {
|
|
|
|
$this->text(', ');
|
|
|
|
} else {
|
|
|
|
$first = false;
|
|
|
|
}
|
|
|
|
|
|
|
|
$this->element('a', array('href' => $url),
|
|
|
|
$lists->tag);
|
2011-04-15 05:57:50 +09:00
|
|
|
}
|
|
|
|
|
|
|
|
$this->elementEnd('ul');
|
|
|
|
|
|
|
|
Event::handle('EndShowListsMiniList', array($this));
|
|
|
|
}
|
|
|
|
$this->elementEnd('div');
|
|
|
|
}
|
|
|
|
}
|
2009-05-19 06:18:57 +09:00
|
|
|
}
|
|
|
|
|
2010-04-05 23:22:54 +09:00
|
|
|
class SubscribersMiniList extends ProfileMiniList
|
|
|
|
{
|
|
|
|
function newListItem($profile)
|
|
|
|
{
|
|
|
|
return new SubscribersMiniListItem($profile, $this->action);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
class SubscribersMiniListItem extends ProfileMiniListItem
|
|
|
|
{
|
2010-04-05 23:46:55 +09:00
|
|
|
function linkAttributes()
|
2010-04-05 23:22:54 +09:00
|
|
|
{
|
2010-04-05 23:46:55 +09:00
|
|
|
$aAttrs = parent::linkAttributes();
|
|
|
|
if (common_config('nofollow', 'subscribers')) {
|
|
|
|
$aAttrs['rel'] .= ' nofollow';
|
2010-04-05 23:22:54 +09:00
|
|
|
}
|
2010-04-05 23:46:55 +09:00
|
|
|
return $aAttrs;
|
2010-04-05 23:22:54 +09:00
|
|
|
}
|
|
|
|
}
|