Add image to JSON ActivityObject and title + links to the JSON document

This commit is contained in:
Zach Copley 2011-02-16 16:21:46 -08:00
parent 764a29e2ff
commit e4d5c47ebf
4 changed files with 136 additions and 6 deletions

View File

@ -266,6 +266,8 @@ class ApiTimelineFriendsAction extends ApiBareAuthAction
case 'as': case 'as':
header('Content-Type: application/json; charset=utf-8'); header('Content-Type: application/json; charset=utf-8');
$doc = new ActivityStreamJSONDocument($this->auth_user); $doc = new ActivityStreamJSONDocument($this->auth_user);
$doc->setTitle($title);
$doc->addLink($link,'alternate', 'text/html');
$doc->addItemsFromNotices($this->notices); $doc->addItemsFromNotices($this->notices);
$this->raw($doc->asString()); $this->raw($doc->asString());
break; break;

View File

@ -387,7 +387,7 @@ class Activity
// TODO: extensions (ActivityContext, OStatus stuff, etc.) // TODO: extensions (ActivityContext, OStatus stuff, etc.)
return $activity; return array_filter($activity);
} }
function asString($namespace=false, $author=true, $source=false) function asString($namespace=false, $author=true, $source=false)

View File

@ -652,13 +652,35 @@ class ActivityObject
// TODO: downstreamDuplicates // TODO: downstreamDuplicates
// TODO: embedCode // TODO: embedCode (video)
// id // id
$object['id'] = $this->id; $object['id'] = $this->id;
// TODO: image if ($this->type == ActivityObject::PERSON
// Need to make MediaLink serialization || $this->type == ActivityObject::GROUP) {
// XXX: Not sure what the best avatar is to use for the
// author's "image". For now, I'm using the stream size
// one, but possibly it should be large
$avatarLink = null;
foreach ($this->avatarLinks as $a) {
if ($a->height == AVATAR_STREAM_SIZE) {
$avatarLink = $a;
break;
}
}
$imgLink = new ActivityStreamsMediaLink(
$avatarLink->url,
$avatarLink->width,
$avatarLink->height,
$avatarLink->type
);
$object['image'] = $imgLink->asArray();
}
// objectType // objectType
$object['type'] = $this->type; $object['type'] = $this->type;
@ -673,6 +695,6 @@ class ActivityObject
// TODO: extensions (OStatus stuff, etc.) // TODO: extensions (OStatus stuff, etc.)
return $object; return array_filter($object);
} }
} }

View File

@ -43,6 +43,7 @@ if (!defined('STATUSNET'))
*/ */
class ActivityStreamJSONDocument class ActivityStreamJSONDocument
{ {
/* Top level array representing the document */ /* Top level array representing the document */
protected $doc = array(); protected $doc = array();
@ -57,9 +58,28 @@ class ActivityStreamJSONDocument
function __construct($cur = null) function __construct($cur = null)
{ {
$this->cur = $cur; $this->cur = $cur;
/* Title of the JSON document */
$this->doc['title'] = null;
/* Array of activity items */
$this->doc['items'] = array(); $this->doc['items'] = array();
/* Array of links associated with the document */
$this->doc['links'] = array();
}
/**
* Set the title of the document
*
* @param String $title the title
*/
function setTitle($title)
{
$this->doc['title'] = $title;
} }
/** /**
@ -99,6 +119,18 @@ class ActivityStreamJSONDocument
array_push($this->doc['items'], $act->asArray()); array_push($this->doc['items'], $act->asArray());
} }
/**
* Add a link to the JSON document
*
* @param string $url the URL for the link
* @param string $rel the link relationship
*/
function addLink($url = null, $rel = null, $mediaType = null)
{
$link = new ActivityStreamsLink($url, $rel, $mediaType);
$this->doc['link'][] = $link->asArray();
}
/* /*
* Return the entire document as a big string of JSON * Return the entire document as a big string of JSON
* *
@ -106,7 +138,81 @@ class ActivityStreamJSONDocument
*/ */
function asString() function asString()
{ {
return json_encode($this->doc); return json_encode(array_filter($this->doc));
} }
} }
/**
* A class for representing MediaLinks in JSON Activities
*
* @category Feed
* @package StatusNet
* @author Zach Copley <zach@status.net>
* @license http://www.fsf.org/licensing/licenses/agpl-3.0.html GNU Affero General Public License version 3.0
* @link http://status.net/
*/
class ActivityStreamsMediaLink extends ActivityStreamsLink
{
private $linkDict;
function __construct(
$url = null,
$width = null,
$height = null,
$mediaType = null,
$rel = null,
$duration = null
)
{
parent::__construct($url, $rel, $mediaType);
$this->linkDict = array(
'width' => $width,
'height' => $height,
'duration' => $duration
);
}
function asArray()
{
return array_merge(
parent::asArray(),
array_filter($this->linkDict)
);
}
}
/**
* A class for representing links in JSON Activities
*
* @category Feed
* @package StatusNet
* @author Zach Copley <zach@status.net>
* @license http://www.fsf.org/licensing/licenses/agpl-3.0.html GNU Affero General Public License version 3.0
* @link http://status.net/
*/
class ActivityStreamsLink
{
private $linkDict;
function __construct($url = null, $rel = null, $mediaType = null)
{
// links MUST have a URL
if (empty($url)) {
throw new Exception('Links must have a URL.');
}
$this->linkDict = array(
'url' => $url,
'rel' => $rel, // extension
'media_type' => $mediaType // extension
);
}
function asArray()
{
return array_filter($this->linkDict);
}
}