X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=lib%2Factivitycontext.php;h=2eff3fb15fb1605513681efd16f32d25ed75786c;hb=14fe22e4307044f2eb08264a7b83f9c2de245dba;hp=f568c791ffd68dce490acce31c20630b21cf6b80;hpb=d207f19d227c675329db3f339d865c9b45219af2;p=quix0rs-gnu-social.git diff --git a/lib/activitycontext.php b/lib/activitycontext.php index f568c791ff..2eff3fb15f 100644 --- a/lib/activitycontext.php +++ b/lib/activitycontext.php @@ -39,6 +39,8 @@ class ActivityContext public $location; public $attention = array(); public $conversation; + public $forwardID; // deprecated, use ActivityVerb::SHARE instead + public $forwardUrl; // deprecated, use ActivityVerb::SHARE instead const THR = 'http://purl.org/syndication/thread/1.0'; const GEORSS = 'http://www.georss.org/georss'; @@ -77,7 +79,6 @@ class ActivityContext $attention = array(); for ($i = 0; $i < $links->length; $i++) { - $link = $links->item($i); $linkRel = $link->getAttribute(ActivityUtils::REL); @@ -129,4 +130,80 @@ class ActivityContext common_log(LOG_ERR, "Ignoring bogus georss:point value $point"); return null; } + + /** + * Returns context (StatusNet stuff) as an array suitable for serializing + * in JSON. Right now context stuff is an extension to Activity. + * + * @return array the context + */ + + function asArray() + { + $context = array(); + + $context['inReplyTo'] = $this->getInReplyToArray(); + $context['conversation'] = $this->conversation; + $context['forwardId'] = $this->forwardID; + $context['forwardUrl'] = $this->forwardUrl; + + return array_filter($context); + } + + /** + * Returns an array of arrays representing Activity Objects (intended to be + * serialized in JSON) that represent WHO the Activity is supposed to + * be received by. This is not really specified but appears in an example + * of the current spec as an extension. We might want to figure out a JSON + * serialization for OStatus and use that to express mentions instead. + * + * XXX: People's ideas on how to do this are all over the place + * + * @return array the array of recipients + */ + + function getToArray() + { + $tos = array(); + + foreach ($this->attention as $attnUrl) { + $to = array( + 'objectType' => 'person', + 'id' => $attnUrl, + 'url' => $attnUrl + ); + $tos[] = $to; + } + + return $tos; + } + + /** + * Return an array for the notices this notice is a reply to + * suitable for serializing as JSON note objects. + * + * @return array the array of notes + */ + + function getInReplyToArray() + { + if (empty($this->replyToID) && empty($this->replyToUrl)) { + return null; + } + + $replyToObj = array('objectType' => 'note'); + + // XXX: Possibly shorten this to just the numeric ID? + // Currently, it's the full URI of the notice. + if (!empty($this->replyToID)) { + $replyToObj['id'] = $this->replyToID; + } + if (!empty($this->replyToUrl)) { + $replyToObj['url'] = $this->replyToUrl; + } + + return $replyToObj; + } + } +