- More useful group info from api/statusnet/group/show
- Add statusnet:group_info tag to group Atom feeds
This commit is contained in:
parent
327ed5b87e
commit
d3d499879c
@ -430,14 +430,6 @@ class ShowgroupAction extends GroupDesignAction
|
|||||||
|
|
||||||
function showStatistics()
|
function showStatistics()
|
||||||
{
|
{
|
||||||
// XXX: WORM cache this
|
|
||||||
$members = $this->group->getMembers();
|
|
||||||
$members_count = 0;
|
|
||||||
/** $member->count() doesn't work. */
|
|
||||||
while ($members->fetch()) {
|
|
||||||
$members_count++;
|
|
||||||
}
|
|
||||||
|
|
||||||
$this->elementStart('div', array('id' => 'entity_statistics',
|
$this->elementStart('div', array('id' => 'entity_statistics',
|
||||||
'class' => 'section'));
|
'class' => 'section'));
|
||||||
|
|
||||||
@ -451,7 +443,7 @@ class ShowgroupAction extends GroupDesignAction
|
|||||||
|
|
||||||
$this->elementStart('dl', 'entity_members');
|
$this->elementStart('dl', 'entity_members');
|
||||||
$this->element('dt', null, _('Members'));
|
$this->element('dt', null, _('Members'));
|
||||||
$this->element('dd', null, (is_int($members_count)) ? $members_count : '0');
|
$this->element('dd', null, $this->group->getMemberCount());
|
||||||
$this->elementEnd('dl');
|
$this->elementEnd('dl');
|
||||||
|
|
||||||
$this->elementEnd('div');
|
$this->elementEnd('div');
|
||||||
|
@ -154,6 +154,21 @@ class User_group extends Memcached_DataObject
|
|||||||
return $members;
|
return $members;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function getMemberCount()
|
||||||
|
{
|
||||||
|
// XXX: WORM cache this
|
||||||
|
|
||||||
|
$members = $this->getMembers();
|
||||||
|
$member_count = 0;
|
||||||
|
|
||||||
|
/** $member->count() doesn't work. */
|
||||||
|
while ($members->fetch()) {
|
||||||
|
$member_count++;
|
||||||
|
}
|
||||||
|
|
||||||
|
return $member_count;
|
||||||
|
}
|
||||||
|
|
||||||
function getAdmins($offset=0, $limit=null)
|
function getAdmins($offset=0, $limit=null)
|
||||||
{
|
{
|
||||||
$qry =
|
$qry =
|
||||||
|
@ -347,10 +347,21 @@ class ApiAction extends Action
|
|||||||
function twitterGroupArray($group)
|
function twitterGroupArray($group)
|
||||||
{
|
{
|
||||||
$twitter_group = array();
|
$twitter_group = array();
|
||||||
|
|
||||||
$twitter_group['id'] = $group->id;
|
$twitter_group['id'] = $group->id;
|
||||||
$twitter_group['url'] = $group->permalink();
|
$twitter_group['url'] = $group->permalink();
|
||||||
$twitter_group['nickname'] = $group->nickname;
|
$twitter_group['nickname'] = $group->nickname;
|
||||||
$twitter_group['fullname'] = $group->fullname;
|
$twitter_group['fullname'] = $group->fullname;
|
||||||
|
|
||||||
|
if (isset($this->auth_user)) {
|
||||||
|
$twitter_group['member'] = $this->auth_user->isMember($group);
|
||||||
|
$twitter_group['blocked'] = Group_block::isBlocked(
|
||||||
|
$group,
|
||||||
|
$this->auth_user->getProfile()
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
$twitter_group['member_count'] = $group->getMemberCount();
|
||||||
$twitter_group['original_logo'] = $group->original_logo;
|
$twitter_group['original_logo'] = $group->original_logo;
|
||||||
$twitter_group['homepage_logo'] = $group->homepage_logo;
|
$twitter_group['homepage_logo'] = $group->homepage_logo;
|
||||||
$twitter_group['stream_logo'] = $group->stream_logo;
|
$twitter_group['stream_logo'] = $group->stream_logo;
|
||||||
@ -360,6 +371,7 @@ class ApiAction extends Action
|
|||||||
$twitter_group['location'] = $group->location;
|
$twitter_group['location'] = $group->location;
|
||||||
$twitter_group['created'] = $this->dateTwitter($group->created);
|
$twitter_group['created'] = $this->dateTwitter($group->created);
|
||||||
$twitter_group['modified'] = $this->dateTwitter($group->modified);
|
$twitter_group['modified'] = $this->dateTwitter($group->modified);
|
||||||
|
|
||||||
return $twitter_group;
|
return $twitter_group;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -93,4 +93,23 @@ class AtomGroupNoticeFeed extends AtomNoticeFeed
|
|||||||
return $this->group;
|
return $this->group;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function initFeed()
|
||||||
|
{
|
||||||
|
parent::initFeed();
|
||||||
|
|
||||||
|
$attrs = array();
|
||||||
|
|
||||||
|
if (!empty($this->cur)) {
|
||||||
|
$attrs['member'] = $this->cur->isMember($this->group)
|
||||||
|
? 'true' : 'false';
|
||||||
|
$attrs['blocked'] = Group_block::isBlocked(
|
||||||
|
$this->group,
|
||||||
|
$this->cur->getProfile()
|
||||||
|
) ? 'true' : 'false';
|
||||||
|
}
|
||||||
|
|
||||||
|
$attrs['member_count'] = $this->group->getMemberCount();
|
||||||
|
|
||||||
|
$this->element('statusnet:group_info', $attrs, null);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user