exit(1);
}
-require_once INSTALLDIR . '/lib/apiprivateauth.php';
-
/**
* Returns the most recent notices (default 20) posted to the group specified by ID
*
* @license http://www.fsf.org/licensing/licenses/agpl-3.0.html GNU Affero General Public License version 3.0
* @link http://status.net/
*/
-
class ApiTimelineGroupAction extends ApiPrivateAuthAction
{
-
var $group = null;
var $notices = null;
* @return boolean success flag
*
*/
-
- function prepare($args)
+ protected function prepare(array $args=array())
{
parent::prepare($args);
*
* Just show the notices
*
- * @param array $args $_REQUEST data (unused)
- *
* @return void
*/
-
- function handle($args)
+ protected function handle()
{
- parent::handle($args);
+ parent::handle();
if (empty($this->group)) {
- $this->clientError(_('Group not found.'), 404, $this->format);
- return false;
+ // TRANS: Client error displayed requesting most recent notices to a group for a non-existing group.
+ $this->clientError(_('Group not found.'), 404);
}
$this->notices = $this->getNotices();
*
* @return void
*/
-
function showTimeline()
{
// We'll pull common formatting out of this for other formats
$self = $this->getSelfUri();
+ $link = common_local_url('showgroup',
+ array('nickname' => $this->group->nickname));
+
switch($this->format) {
case 'xml':
$this->showXmlTimeline($this->notices);
);
break;
case 'atom':
-
header('Content-Type: application/atom+xml; charset=utf-8');
-
- try {
- $atom->addAuthorRaw($this->group->asAtomAuthor());
- $atom->setActivitySubject($this->group->asActivitySubject());
- $atom->setId($self);
- $atom->setSelfLink($self);
$atom->addEntryFromNotices($this->notices);
$this->raw($atom->getString());
- } catch (Atom10FeedException $e) {
- $this->serverError(
- 'Could not generate feed for group - ' . $e->getMessage(),
- 400,
- $this->format
- );
- return;
- }
-
break;
case 'json':
$this->showJsonTimeline($this->notices);
break;
- default:
- $this->clientError(
- _('API method not found.'),
- 404,
- $this->format
- );
+ case 'as':
+ header('Content-Type: ' . ActivityStreamJSONDocument::CONTENT_TYPE);
+ $doc = new ActivityStreamJSONDocument($this->auth_user);
+ $doc->setTitle($atom->title);
+ $doc->addLink($link, 'alternate', 'text/html');
+ $doc->addItemsFromNotices($this->notices);
+ $this->raw($doc->asString());
break;
+ default:
+ // TRANS: Client error displayed when trying to handle an unknown API method.
+ $this->clientError(_('API method not found.'), 404);
}
}
*
* @return array notices
*/
-
function getNotices()
{
$notices = array();
*
* @return boolean true
*/
-
- function isReadOnly($args)
+ function isReadOnly(array $args=array())
{
return true;
}
*
* @return string datestamp of the latest notice in the stream
*/
-
function lastModified()
{
if (!empty($this->notices) && (count($this->notices) > 0)) {
*
* @return string etag
*/
-
function etag()
{
if (!empty($this->notices) && (count($this->notices) > 0)) {
return '"' . implode(
':',
array($this->arg('action'),
+ common_user_cache_hash($this->auth_user),
common_language(),
$this->group->id,
strtotime($this->notices[0]->created),
return null;
}
-
}