Add docs
This commit is contained in:
parent
a83dfc11a0
commit
3897c74deb
21 changed files with 439 additions and 122 deletions
|
@ -27,12 +27,12 @@ use Friendica\Model\Term;
|
||||||
use Friendica\Object\Post;
|
use Friendica\Object\Post;
|
||||||
use Friendica\Object\Thread;
|
use Friendica\Object\Thread;
|
||||||
use Friendica\Protocol\Activity;
|
use Friendica\Protocol\Activity;
|
||||||
|
use Friendica\Util\Crypto;
|
||||||
use Friendica\Util\DateTimeFormat;
|
use Friendica\Util\DateTimeFormat;
|
||||||
use Friendica\Util\Proxy as ProxyUtils;
|
use Friendica\Util\Proxy as ProxyUtils;
|
||||||
use Friendica\Util\Temporal;
|
|
||||||
use Friendica\Util\Strings;
|
use Friendica\Util\Strings;
|
||||||
|
use Friendica\Util\Temporal;
|
||||||
use Friendica\Util\XML;
|
use Friendica\Util\XML;
|
||||||
use Friendica\Util\Crypto;
|
|
||||||
|
|
||||||
function item_extract_images($body) {
|
function item_extract_images($body) {
|
||||||
|
|
||||||
|
@ -163,7 +163,7 @@ function localize_item(&$item)
|
||||||
switch ($obj['verb']) {
|
switch ($obj['verb']) {
|
||||||
case Activity::POST:
|
case Activity::POST:
|
||||||
switch ($obj['object-type']) {
|
switch ($obj['object-type']) {
|
||||||
case Activity::OBJ_EVENT:
|
case Activity\ObjectType::EVENT:
|
||||||
$post_type = L10n::t('event');
|
$post_type = L10n::t('event');
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
|
@ -201,7 +201,7 @@ function localize_item(&$item)
|
||||||
|
|
||||||
if ($activity->match($item['verb'], Activity::FRIEND)) {
|
if ($activity->match($item['verb'], Activity::FRIEND)) {
|
||||||
|
|
||||||
if ($item['object-type']=="" || $item['object-type']!== Activity::OBJ_PERSON) return;
|
if ($item['object-type']=="" || $item['object-type']!== Activity\ObjectType::PERSON) return;
|
||||||
|
|
||||||
$Aname = $item['author-name'];
|
$Aname = $item['author-name'];
|
||||||
$Alink = $item['author-link'];
|
$Alink = $item['author-link'];
|
||||||
|
@ -236,7 +236,7 @@ function localize_item(&$item)
|
||||||
if (!$verb) {
|
if (!$verb) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if ($item['object-type']=="" || $item['object-type']!== Activity::OBJ_PERSON) {
|
if ($item['object-type']=="" || $item['object-type']!== Activity\ObjectType::PERSON) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -300,7 +300,7 @@ function localize_item(&$item)
|
||||||
switch ($obj['verb']) {
|
switch ($obj['verb']) {
|
||||||
case Activity::POST:
|
case Activity::POST:
|
||||||
switch ($obj['object-type']) {
|
switch ($obj['object-type']) {
|
||||||
case Activity::OBJ_EVENT:
|
case Activity\ObjectType::EVENT:
|
||||||
$post_type = L10n::t('event');
|
$post_type = L10n::t('event');
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
|
@ -408,7 +408,7 @@ function visible_activity($item) {
|
||||||
|
|
||||||
// @TODO below if() block can be rewritten to a single line: $isVisible = allConditionsHere;
|
// @TODO below if() block can be rewritten to a single line: $isVisible = allConditionsHere;
|
||||||
if ($activity->match($item['verb'], Activity::FOLLOW) &&
|
if ($activity->match($item['verb'], Activity::FOLLOW) &&
|
||||||
$item['object-type'] === Activity::OBJ_NOTE &&
|
$item['object-type'] === Activity\ObjectType::NOTE &&
|
||||||
empty($item['self']) &&
|
empty($item['self']) &&
|
||||||
$item['uid'] == local_user()) {
|
$item['uid'] == local_user()) {
|
||||||
return false;
|
return false;
|
||||||
|
|
14
mod/item.php
14
mod/item.php
|
@ -134,7 +134,7 @@ function item_post(App $a) {
|
||||||
$toplevel_item_id = $toplevel_item['id'];
|
$toplevel_item_id = $toplevel_item['id'];
|
||||||
$parent_user = $toplevel_item['uid'];
|
$parent_user = $toplevel_item['uid'];
|
||||||
|
|
||||||
$objecttype = Activity::OBJ_COMMENT;
|
$objecttype = Activity\ObjectType::COMMENT;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($toplevel_item_id) {
|
if ($toplevel_item_id) {
|
||||||
|
@ -467,7 +467,7 @@ function item_post(App $a) {
|
||||||
$match = null;
|
$match = null;
|
||||||
|
|
||||||
if (!$preview && Photo::setPermissionFromBody($body, $profile_uid, $original_contact_id, $str_contact_allow, $str_group_allow, $str_contact_deny, $str_group_deny)) {
|
if (!$preview && Photo::setPermissionFromBody($body, $profile_uid, $original_contact_id, $str_contact_allow, $str_group_allow, $str_contact_deny, $str_group_deny)) {
|
||||||
$objecttype = Activity::OBJ_IMAGE;
|
$objecttype = Activity\ObjectType::IMAGE;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -503,7 +503,7 @@ function item_post(App $a) {
|
||||||
if ((preg_match_all("/\[bookmark\=([^\]]*)\](.*?)\[\/bookmark\]/ism", $body, $match, PREG_SET_ORDER) || isset($data["type"]))
|
if ((preg_match_all("/\[bookmark\=([^\]]*)\](.*?)\[\/bookmark\]/ism", $body, $match, PREG_SET_ORDER) || isset($data["type"]))
|
||||||
&& ($posttype != Item::PT_PERSONAL_NOTE)) {
|
&& ($posttype != Item::PT_PERSONAL_NOTE)) {
|
||||||
$posttype = Item::PT_PAGE;
|
$posttype = Item::PT_PAGE;
|
||||||
$objecttype = Activity::OBJ_BOOKMARK;
|
$objecttype = Activity\ObjectType::BOOKMARK;
|
||||||
}
|
}
|
||||||
|
|
||||||
/** @var BBCode\Video $bbCodeVideo */
|
/** @var BBCode\Video $bbCodeVideo */
|
||||||
|
@ -517,15 +517,15 @@ function item_post(App $a) {
|
||||||
|
|
||||||
// Setting the object type if not defined before
|
// Setting the object type if not defined before
|
||||||
if (!$objecttype) {
|
if (!$objecttype) {
|
||||||
$objecttype = Activity::OBJ_NOTE; // Default value
|
$objecttype = Activity\ObjectType::NOTE; // Default value
|
||||||
$objectdata = BBCode::getAttachedData($body);
|
$objectdata = BBCode::getAttachedData($body);
|
||||||
|
|
||||||
if ($objectdata["type"] == "link") {
|
if ($objectdata["type"] == "link") {
|
||||||
$objecttype = Activity::OBJ_BOOKMARK;
|
$objecttype = Activity\ObjectType::BOOKMARK;
|
||||||
} elseif ($objectdata["type"] == "video") {
|
} elseif ($objectdata["type"] == "video") {
|
||||||
$objecttype = Activity::OBJ_VIDEO;
|
$objecttype = Activity\ObjectType::VIDEO;
|
||||||
} elseif ($objectdata["type"] == "photo") {
|
} elseif ($objectdata["type"] == "photo") {
|
||||||
$objecttype = Activity::OBJ_IMAGE;
|
$objecttype = Activity\ObjectType::IMAGE;
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -569,22 +569,22 @@ function photos_post(App $a)
|
||||||
$arr['visible'] = 1;
|
$arr['visible'] = 1;
|
||||||
$arr['verb'] = Activity::TAG;
|
$arr['verb'] = Activity::TAG;
|
||||||
$arr['gravity'] = GRAVITY_PARENT;
|
$arr['gravity'] = GRAVITY_PARENT;
|
||||||
$arr['object-type'] = Activity::OBJ_PERSON;
|
$arr['object-type'] = Activity\ObjectType::PERSON;
|
||||||
$arr['target-type'] = Activity::OBJ_IMAGE;
|
$arr['target-type'] = Activity\ObjectType::IMAGE;
|
||||||
$arr['tag'] = $tagged[4];
|
$arr['tag'] = $tagged[4];
|
||||||
$arr['inform'] = $tagged[2];
|
$arr['inform'] = $tagged[2];
|
||||||
$arr['origin'] = 1;
|
$arr['origin'] = 1;
|
||||||
$arr['body'] = L10n::t('%1$s was tagged in %2$s by %3$s', '[url=' . $tagged[1] . ']' . $tagged[0] . '[/url]', '[url=' . System::baseUrl() . '/photos/' . $owner_record['nickname'] . '/image/' . $photo['resource-id'] . ']' . L10n::t('a photo') . '[/url]', '[url=' . $owner_record['url'] . ']' . $owner_record['name'] . '[/url]') ;
|
$arr['body'] = L10n::t('%1$s was tagged in %2$s by %3$s', '[url=' . $tagged[1] . ']' . $tagged[0] . '[/url]', '[url=' . System::baseUrl() . '/photos/' . $owner_record['nickname'] . '/image/' . $photo['resource-id'] . ']' . L10n::t('a photo') . '[/url]', '[url=' . $owner_record['url'] . ']' . $owner_record['name'] . '[/url]') ;
|
||||||
$arr['body'] .= "\n\n" . '[url=' . System::baseUrl() . '/photos/' . $owner_record['nickname'] . '/image/' . $photo['resource-id'] . ']' . '[img]' . System::baseUrl() . "/photo/" . $photo['resource-id'] . '-' . $best . '.' . $ext . '[/img][/url]' . "\n" ;
|
$arr['body'] .= "\n\n" . '[url=' . System::baseUrl() . '/photos/' . $owner_record['nickname'] . '/image/' . $photo['resource-id'] . ']' . '[img]' . System::baseUrl() . "/photo/" . $photo['resource-id'] . '-' . $best . '.' . $ext . '[/img][/url]' . "\n" ;
|
||||||
|
|
||||||
$arr['object'] = '<object><type>' . Activity::OBJ_PERSON . '</type><title>' . $tagged[0] . '</title><id>' . $tagged[1] . '/' . $tagged[0] . '</id>';
|
$arr['object'] = '<object><type>' . Activity\ObjectType::PERSON . '</type><title>' . $tagged[0] . '</title><id>' . $tagged[1] . '/' . $tagged[0] . '</id>';
|
||||||
$arr['object'] .= '<link>' . XML::escape('<link rel="alternate" type="text/html" href="' . $tagged[1] . '" />' . "\n");
|
$arr['object'] .= '<link>' . XML::escape('<link rel="alternate" type="text/html" href="' . $tagged[1] . '" />' . "\n");
|
||||||
if ($tagged[3]) {
|
if ($tagged[3]) {
|
||||||
$arr['object'] .= XML::escape('<link rel="photo" type="' . $photo['type'] . '" href="' . $tagged[3]['photo'] . '" />' . "\n");
|
$arr['object'] .= XML::escape('<link rel="photo" type="' . $photo['type'] . '" href="' . $tagged[3]['photo'] . '" />' . "\n");
|
||||||
}
|
}
|
||||||
$arr['object'] .= '</link></object>' . "\n";
|
$arr['object'] .= '</link></object>' . "\n";
|
||||||
|
|
||||||
$arr['target'] = '<target><type>' . Activity::OBJ_IMAGE . '</type><title>' . $photo['desc'] . '</title><id>'
|
$arr['target'] = '<target><type>' . Activity\ObjectType::IMAGE . '</type><title>' . $photo['desc'] . '</title><id>'
|
||||||
. System::baseUrl() . '/photos/' . $owner_record['nickname'] . '/image/' . $photo['resource-id'] . '</id>';
|
. System::baseUrl() . '/photos/' . $owner_record['nickname'] . '/image/' . $photo['resource-id'] . '</id>';
|
||||||
$arr['target'] .= '<link>' . XML::escape('<link rel="alternate" type="text/html" href="' . System::baseUrl() . '/photos/' . $owner_record['nickname'] . '/image/' . $photo['resource-id'] . '" />' . "\n" . '<link rel="preview" type="' . $photo['type'] . '" href="' . System::baseUrl() . "/photo/" . $photo['resource-id'] . '-' . $best . '.' . $ext . '" />') . '</link></target>';
|
$arr['target'] .= '<link>' . XML::escape('<link rel="alternate" type="text/html" href="' . System::baseUrl() . '/photos/' . $owner_record['nickname'] . '/image/' . $photo['resource-id'] . '" />' . "\n" . '<link rel="preview" type="' . $photo['type'] . '" href="' . System::baseUrl() . "/photo/" . $photo['resource-id'] . '-' . $best . '.' . $ext . '" />') . '</link></target>';
|
||||||
|
|
||||||
|
|
|
@ -118,12 +118,12 @@ function poke_init(App $a)
|
||||||
$arr['visible'] = 1;
|
$arr['visible'] = 1;
|
||||||
$arr['verb'] = $activity;
|
$arr['verb'] = $activity;
|
||||||
$arr['private'] = $private;
|
$arr['private'] = $private;
|
||||||
$arr['object-type'] = Activity::OBJ_PERSON;
|
$arr['object-type'] = Activity\ObjectType::PERSON;
|
||||||
|
|
||||||
$arr['origin'] = 1;
|
$arr['origin'] = 1;
|
||||||
$arr['body'] = '[url=' . $poster['url'] . ']' . $poster['name'] . '[/url]' . ' ' . L10n::t($verbs[$verb][0]) . ' ' . '[url=' . $target['url'] . ']' . $target['name'] . '[/url]';
|
$arr['body'] = '[url=' . $poster['url'] . ']' . $poster['name'] . '[/url]' . ' ' . L10n::t($verbs[$verb][0]) . ' ' . '[url=' . $target['url'] . ']' . $target['name'] . '[/url]';
|
||||||
|
|
||||||
$arr['object'] = '<object><type>' . Activity::OBJ_PERSON . '</type><title>' . $target['name'] . '</title><id>' . $target['url'] . '</id>';
|
$arr['object'] = '<object><type>' . Activity\ObjectType::PERSON . '</type><title>' . $target['name'] . '</title><id>' . $target['url'] . '</id>';
|
||||||
$arr['object'] .= '<link>' . XML::escape('<link rel="alternate" type="text/html" href="' . $target['url'] . '" />' . "\n");
|
$arr['object'] .= '<link>' . XML::escape('<link rel="alternate" type="text/html" href="' . $target['url'] . '" />' . "\n");
|
||||||
|
|
||||||
$arr['object'] .= XML::escape('<link rel="photo" type="image/jpeg" href="' . $target['photo'] . '" />' . "\n");
|
$arr['object'] .= XML::escape('<link rel="photo" type="image/jpeg" href="' . $target['photo'] . '" />' . "\n");
|
||||||
|
|
|
@ -2,6 +2,7 @@
|
||||||
/**
|
/**
|
||||||
* @file mod/subthread.php
|
* @file mod/subthread.php
|
||||||
*/
|
*/
|
||||||
|
|
||||||
use Friendica\App;
|
use Friendica\App;
|
||||||
use Friendica\Core\Hook;
|
use Friendica\Core\Hook;
|
||||||
use Friendica\Core\L10n;
|
use Friendica\Core\L10n;
|
||||||
|
@ -88,7 +89,7 @@ function subthread_content(App $a) {
|
||||||
$uri = Item::newURI($owner_uid);
|
$uri = Item::newURI($owner_uid);
|
||||||
|
|
||||||
$post_type = (($item['resource-id']) ? L10n::t('photo') : L10n::t('status'));
|
$post_type = (($item['resource-id']) ? L10n::t('photo') : L10n::t('status'));
|
||||||
$objtype = (($item['resource-id']) ? Activity::OBJ_IMAGE : Activity::OBJ_NOTE );
|
$objtype = (($item['resource-id']) ? Activity\ObjectType::IMAGE : Activity\ObjectType::NOTE );
|
||||||
$link = XML::escape('<link rel="alternate" type="text/html" href="' . System::baseUrl() . '/display/' . $item['guid'] . '" />' . "\n");
|
$link = XML::escape('<link rel="alternate" type="text/html" href="' . System::baseUrl() . '/display/' . $item['guid'] . '" />' . "\n");
|
||||||
$body = $item['body'];
|
$body = $item['body'];
|
||||||
|
|
||||||
|
|
|
@ -2,12 +2,13 @@
|
||||||
/**
|
/**
|
||||||
* @file mod/tagger.php
|
* @file mod/tagger.php
|
||||||
*/
|
*/
|
||||||
|
|
||||||
use Friendica\App;
|
use Friendica\App;
|
||||||
use Friendica\Core\Hook;
|
use Friendica\Core\Hook;
|
||||||
use Friendica\Core\L10n;
|
use Friendica\Core\L10n;
|
||||||
use Friendica\Core\Logger;
|
use Friendica\Core\Logger;
|
||||||
use Friendica\Core\System;
|
|
||||||
use Friendica\Core\Session;
|
use Friendica\Core\Session;
|
||||||
|
use Friendica\Core\System;
|
||||||
use Friendica\Core\Worker;
|
use Friendica\Core\Worker;
|
||||||
use Friendica\Database\DBA;
|
use Friendica\Database\DBA;
|
||||||
use Friendica\Model\Item;
|
use Friendica\Model\Item;
|
||||||
|
@ -69,7 +70,7 @@ function tagger_content(App $a) {
|
||||||
$uri = Item::newURI($owner_uid);
|
$uri = Item::newURI($owner_uid);
|
||||||
$xterm = XML::escape($term);
|
$xterm = XML::escape($term);
|
||||||
$post_type = (($item['resource-id']) ? L10n::t('photo') : L10n::t('status'));
|
$post_type = (($item['resource-id']) ? L10n::t('photo') : L10n::t('status'));
|
||||||
$targettype = (($item['resource-id']) ? Activity::OBJ_IMAGE : Activity::OBJ_NOTE );
|
$targettype = (($item['resource-id']) ? Activity\ObjectType::IMAGE : Activity\ObjectType::NOTE );
|
||||||
$href = System::baseUrl() . '/display/' . $item['guid'];
|
$href = System::baseUrl() . '/display/' . $item['guid'];
|
||||||
|
|
||||||
$link = XML::escape('<link rel="alternate" type="text/html" href="'. $href . '" />' . "\n");
|
$link = XML::escape('<link rel="alternate" type="text/html" href="'. $href . '" />' . "\n");
|
||||||
|
@ -88,7 +89,7 @@ function tagger_content(App $a) {
|
||||||
EOT;
|
EOT;
|
||||||
|
|
||||||
$tagid = System::baseUrl() . '/search?tag=' . $xterm;
|
$tagid = System::baseUrl() . '/search?tag=' . $xterm;
|
||||||
$objtype = Activity::OBJ_TAGTERM;
|
$objtype = Activity\ObjectType::TAGTERM;
|
||||||
|
|
||||||
$obj = <<< EOT
|
$obj = <<< EOT
|
||||||
<object>
|
<object>
|
||||||
|
|
|
@ -277,7 +277,7 @@ class BBCode extends BaseObject
|
||||||
|
|
||||||
if (preg_match_all("(\[url=(.*?)\]\s*\[img\](.*?)\[\/img\]\s*\[\/url\])ism", $body, $pictures, PREG_SET_ORDER)) {
|
if (preg_match_all("(\[url=(.*?)\]\s*\[img\](.*?)\[\/img\]\s*\[\/url\])ism", $body, $pictures, PREG_SET_ORDER)) {
|
||||||
if ((count($pictures) == 1) && !$has_title) {
|
if ((count($pictures) == 1) && !$has_title) {
|
||||||
if (!empty($item['object-type']) && ($item['object-type'] == Activity::OBJ_IMAGE)) {
|
if (!empty($item['object-type']) && ($item['object-type'] == Activity\ObjectType::IMAGE)) {
|
||||||
// Replace the preview picture with the real picture
|
// Replace the preview picture with the real picture
|
||||||
$url = str_replace('-1.', '-0.', $pictures[0][2]);
|
$url = str_replace('-1.', '-0.', $pictures[0][2]);
|
||||||
$data = ['url' => $url, 'type' => 'photo'];
|
$data = ['url' => $url, 'type' => 'photo'];
|
||||||
|
|
|
@ -828,7 +828,7 @@ class Contact extends BaseObject
|
||||||
} elseif (in_array($protocol, [Protocol::OSTATUS, Protocol::DFRN])) {
|
} elseif (in_array($protocol, [Protocol::OSTATUS, Protocol::DFRN])) {
|
||||||
// create an unfollow slap
|
// create an unfollow slap
|
||||||
$item = [];
|
$item = [];
|
||||||
$item['verb'] = Activity\ANamespace::OSTATUS . "/unfollow";
|
$item['verb'] = Activity::O_UNFOLLOW;
|
||||||
$item['follow'] = $contact["url"];
|
$item['follow'] = $contact["url"];
|
||||||
$item['body'] = '';
|
$item['body'] = '';
|
||||||
$item['title'] = '';
|
$item['title'] = '';
|
||||||
|
|
|
@ -304,7 +304,7 @@ class Event extends BaseObject
|
||||||
|
|
||||||
$item = Item::selectFirst(['id'], ['event-id' => $event['id'], 'uid' => $event['uid']]);
|
$item = Item::selectFirst(['id'], ['event-id' => $event['id'], 'uid' => $event['uid']]);
|
||||||
if (DBA::isResult($item)) {
|
if (DBA::isResult($item)) {
|
||||||
$object = '<object><type>' . XML::escape(Activity::OBJ_EVENT) . '</type><title></title><id>' . XML::escape($event['uri']) . '</id>';
|
$object = '<object><type>' . XML::escape(Activity\ObjectType::EVENT) . '</type><title></title><id>' . XML::escape($event['uri']) . '</id>';
|
||||||
$object .= '<content>' . XML::escape(self::getBBCode($event)) . '</content>';
|
$object .= '<content>' . XML::escape(self::getBBCode($event)) . '</content>';
|
||||||
$object .= '</object>' . "\n";
|
$object .= '</object>' . "\n";
|
||||||
|
|
||||||
|
@ -352,12 +352,12 @@ class Event extends BaseObject
|
||||||
$item_arr['private'] = $private;
|
$item_arr['private'] = $private;
|
||||||
$item_arr['visible'] = 1;
|
$item_arr['visible'] = 1;
|
||||||
$item_arr['verb'] = Activity::POST;
|
$item_arr['verb'] = Activity::POST;
|
||||||
$item_arr['object-type'] = Activity::OBJ_EVENT;
|
$item_arr['object-type'] = Activity\ObjectType::EVENT;
|
||||||
$item_arr['origin'] = $event['cid'] === 0 ? 1 : 0;
|
$item_arr['origin'] = $event['cid'] === 0 ? 1 : 0;
|
||||||
$item_arr['body'] = self::getBBCode($event);
|
$item_arr['body'] = self::getBBCode($event);
|
||||||
$item_arr['event-id'] = $event['id'];
|
$item_arr['event-id'] = $event['id'];
|
||||||
|
|
||||||
$item_arr['object'] = '<object><type>' . XML::escape(Activity::OBJ_EVENT) . '</type><title></title><id>' . XML::escape($event['uri']) . '</id>';
|
$item_arr['object'] = '<object><type>' . XML::escape(Activity\ObjectType::EVENT) . '</type><title></title><id>' . XML::escape($event['uri']) . '</id>';
|
||||||
$item_arr['object'] .= '<content>' . XML::escape(self::getBBCode($event)) . '</content>';
|
$item_arr['object'] .= '<content>' . XML::escape(self::getBBCode($event)) . '</content>';
|
||||||
$item_arr['object'] .= '</object>' . "\n";
|
$item_arr['object'] .= '</object>' . "\n";
|
||||||
|
|
||||||
|
|
|
@ -214,7 +214,7 @@ class Item extends BaseObject
|
||||||
$row['object'] = '';
|
$row['object'] = '';
|
||||||
}
|
}
|
||||||
if (array_key_exists('object-type', $row)) {
|
if (array_key_exists('object-type', $row)) {
|
||||||
$row['object-type'] = Activity::OBJ_NOTE;
|
$row['object-type'] = Activity\ObjectType::NOTE;
|
||||||
}
|
}
|
||||||
} elseif (array_key_exists('verb', $row) && in_array($row['verb'], ['', Activity::POST, Activity::SHARE])) {
|
} elseif (array_key_exists('verb', $row) && in_array($row['verb'], ['', Activity::POST, Activity::SHARE])) {
|
||||||
// Posts don't have an object or target - but having tags or files.
|
// Posts don't have an object or target - but having tags or files.
|
||||||
|
@ -1157,14 +1157,14 @@ class Item extends BaseObject
|
||||||
|
|
||||||
private static function deleteTagsFromItem($item)
|
private static function deleteTagsFromItem($item)
|
||||||
{
|
{
|
||||||
if (($item["verb"] != Activity::TAG) || ($item["object-type"] != Activity::OBJ_TAGTERM)) {
|
if (($item["verb"] != Activity::TAG) || ($item["object-type"] != Activity\ObjectType::TAGTERM)) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
$xo = XML::parseString($item["object"], false);
|
$xo = XML::parseString($item["object"], false);
|
||||||
$xt = XML::parseString($item["target"], false);
|
$xt = XML::parseString($item["target"], false);
|
||||||
|
|
||||||
if ($xt->type != Activity::OBJ_NOTE) {
|
if ($xt->type != Activity\ObjectType::NOTE) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -3156,7 +3156,7 @@ class Item extends BaseObject
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
$objtype = $item['resource-id'] ? Activity::OBJ_IMAGE : Activity::OBJ_NOTE;
|
$objtype = $item['resource-id'] ? Activity\ObjectType::IMAGE : Activity\ObjectType::NOTE;
|
||||||
|
|
||||||
$new_item = [
|
$new_item = [
|
||||||
'guid' => System::createUUID(),
|
'guid' => System::createUUID(),
|
||||||
|
@ -3436,7 +3436,7 @@ class Item extends BaseObject
|
||||||
|
|
||||||
// In order to provide theme developers more possibilities, event items
|
// In order to provide theme developers more possibilities, event items
|
||||||
// are treated differently.
|
// are treated differently.
|
||||||
if ($item['object-type'] === Activity::OBJ_EVENT && isset($item['event-id'])) {
|
if ($item['object-type'] === Activity\ObjectType::EVENT && isset($item['event-id'])) {
|
||||||
$ev = Event::getItemHTML($item);
|
$ev = Event::getItemHTML($item);
|
||||||
return $ev;
|
return $ev;
|
||||||
}
|
}
|
||||||
|
|
|
@ -15,8 +15,8 @@ use Friendica\Core\L10n;
|
||||||
use Friendica\Core\Logger;
|
use Friendica\Core\Logger;
|
||||||
use Friendica\Core\PConfig;
|
use Friendica\Core\PConfig;
|
||||||
use Friendica\Core\Protocol;
|
use Friendica\Core\Protocol;
|
||||||
use Friendica\Core\Session;
|
|
||||||
use Friendica\Core\Renderer;
|
use Friendica\Core\Renderer;
|
||||||
|
use Friendica\Core\Session;
|
||||||
use Friendica\Database\DBA;
|
use Friendica\Database\DBA;
|
||||||
use Friendica\Model\Contact;
|
use Friendica\Model\Contact;
|
||||||
use Friendica\Model\Item;
|
use Friendica\Model\Item;
|
||||||
|
@ -240,7 +240,7 @@ class Post extends BaseObject
|
||||||
|
|
||||||
$isevent = false;
|
$isevent = false;
|
||||||
$attend = [];
|
$attend = [];
|
||||||
if ($item['object-type'] === Activity::OBJ_EVENT) {
|
if ($item['object-type'] === Activity\ObjectType::EVENT) {
|
||||||
$response_verbs[] = 'attendyes';
|
$response_verbs[] = 'attendyes';
|
||||||
$response_verbs[] = 'attendno';
|
$response_verbs[] = 'attendno';
|
||||||
$response_verbs[] = 'attendmaybe';
|
$response_verbs[] = 'attendmaybe';
|
||||||
|
|
|
@ -5,50 +5,157 @@ namespace Friendica\Protocol;
|
||||||
use Friendica\Protocol\Activity\ANamespace;
|
use Friendica\Protocol\Activity\ANamespace;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Base class for the Activity constants and particular method
|
* Base class for the Activity Verbs
|
||||||
*/
|
*/
|
||||||
final class Activity
|
final class Activity
|
||||||
{
|
{
|
||||||
const LIKE = ANamespace::ACTIVITY_SCHEMA . 'like';
|
/**
|
||||||
|
* Indicates that the actor marked the object as an item of special interest.
|
||||||
|
*
|
||||||
|
* @see http://activitystrea.ms/head/activity-schema.html#verbs
|
||||||
|
* @var string
|
||||||
|
*/
|
||||||
|
const LIKE = ANamespace::ACTIVITY_SCHEMA . 'like';
|
||||||
|
/**
|
||||||
|
* Dislike a message ("I don't like the post")
|
||||||
|
*
|
||||||
|
* @see http://purl.org/macgirvin/dfrn/1.0/dislike
|
||||||
|
* @var string
|
||||||
|
*/
|
||||||
|
const DISLIKE = ANamespace::DFRN . '/dislike';
|
||||||
|
|
||||||
const DISLIKE = ANamespace::DFRN . '/dislike';
|
/**
|
||||||
const ATTEND = ANamespace::ZOT . '/activity/attendyes';
|
* Attend an event
|
||||||
const ATTENDNO = ANamespace::ZOT . '/activity/attendno';
|
*
|
||||||
const ATTENDMAYBE = ANamespace::ZOT . '/activity/attendmaybe';
|
* @see https://github.com/friendica/friendica/wiki/ActivityStreams#activity_attend
|
||||||
const OBJ_HEART = ANamespace::DFRN . '/heart';
|
* @var string
|
||||||
|
*/
|
||||||
|
const ATTEND = ANamespace::ZOT . '/activity/attendyes';
|
||||||
|
/**
|
||||||
|
* Don't attend an event
|
||||||
|
*
|
||||||
|
* @see https://github.com/friendica/friendica/wiki/ActivityStreams#activity_attendno
|
||||||
|
* @var string
|
||||||
|
*/
|
||||||
|
const ATTENDNO = ANamespace::ZOT . '/activity/attendno';
|
||||||
|
/**
|
||||||
|
* Attend maybe an event
|
||||||
|
*
|
||||||
|
* @see https://github.com/friendica/friendica/wiki/ActivityStreams#activity_attendmaybe
|
||||||
|
* @var string
|
||||||
|
*/
|
||||||
|
const ATTENDMAYBE = ANamespace::ZOT . '/activity/attendmaybe';
|
||||||
|
|
||||||
const FRIEND = ANamespace::ACTIVITY_SCHEMA . 'make-friend';
|
/**
|
||||||
const REQ_FRIEND = ANamespace::ACTIVITY_SCHEMA . 'request-friend';
|
* Indicates the creation of a friendship that is reciprocated by the object.
|
||||||
const UNFRIEND = ANamespace::ACTIVITY_SCHEMA . 'remove-friend';
|
*
|
||||||
const FOLLOW = ANamespace::ACTIVITY_SCHEMA . 'follow';
|
* @see http://activitystrea.ms/head/activity-schema.html#verbs
|
||||||
const UNFOLLOW = ANamespace::ACTIVITY_SCHEMA . 'stop-following';
|
* @var string
|
||||||
const JOIN = ANamespace::ACTIVITY_SCHEMA . 'join';
|
*/
|
||||||
const POST = ANamespace::ACTIVITY_SCHEMA . 'post';
|
const FRIEND = ANamespace::ACTIVITY_SCHEMA . 'make-friend';
|
||||||
const UPDATE = ANamespace::ACTIVITY_SCHEMA . 'update';
|
/**
|
||||||
const TAG = ANamespace::ACTIVITY_SCHEMA . 'tag';
|
* Indicates the creation of a friendship that has not yet been reciprocated by the object.
|
||||||
const FAVORITE = ANamespace::ACTIVITY_SCHEMA . 'favorite';
|
*
|
||||||
const UNFAVORITE = ANamespace::ACTIVITY_SCHEMA . 'unfavorite';
|
* @see http://activitystrea.ms/head/activity-schema.html#verbs
|
||||||
const SHARE = ANamespace::ACTIVITY_SCHEMA . 'share';
|
* @var string
|
||||||
const DELETE = ANamespace::ACTIVITY_SCHEMA . 'delete';
|
*/
|
||||||
const ANNOUNCE = ANamespace::ACTIVITY2 . 'Announce';
|
const REQ_FRIEND = ANamespace::ACTIVITY_SCHEMA . 'request-friend';
|
||||||
|
/**
|
||||||
|
* Indicates that the actor has removed the object from the collection of friends.
|
||||||
|
*
|
||||||
|
* @see http://activitystrea.ms/head/activity-schema.html#verbs
|
||||||
|
* @var string
|
||||||
|
*/
|
||||||
|
const UNFRIEND = ANamespace::ACTIVITY_SCHEMA . 'remove-friend';
|
||||||
|
/**
|
||||||
|
* Indicates that the actor began following the activity of the object.
|
||||||
|
*
|
||||||
|
* @see http://activitystrea.ms/head/activity-schema.html#verbs
|
||||||
|
* @var string
|
||||||
|
*/
|
||||||
|
const FOLLOW = ANamespace::ACTIVITY_SCHEMA . 'follow';
|
||||||
|
/**
|
||||||
|
* Indicates that the actor has stopped following the object.
|
||||||
|
*
|
||||||
|
* @see http://activitystrea.ms/head/activity-schema.html#verbs
|
||||||
|
* @var string
|
||||||
|
*/
|
||||||
|
const UNFOLLOW = ANamespace::ACTIVITY_SCHEMA . 'stop-following';
|
||||||
|
/**
|
||||||
|
* Indicates that the actor has become a member of the object.
|
||||||
|
*
|
||||||
|
* @see http://activitystrea.ms/head/activity-schema.html#verbs
|
||||||
|
* @var string
|
||||||
|
*/
|
||||||
|
const JOIN = ANamespace::ACTIVITY_SCHEMA . 'join';
|
||||||
|
/**
|
||||||
|
* Implementors SHOULD use verbs such as post where the actor is adding new items to a collection or similar.
|
||||||
|
*
|
||||||
|
* @see http://activitystrea.ms/head/activity-schema.html#verbs
|
||||||
|
* @var string
|
||||||
|
*/
|
||||||
|
const POST = ANamespace::ACTIVITY_SCHEMA . 'post';
|
||||||
|
/**
|
||||||
|
* The "update" verb indicates that the actor has modified the object.
|
||||||
|
*
|
||||||
|
* @see http://activitystrea.ms/head/activity-schema.html#verbs
|
||||||
|
* @var string
|
||||||
|
*/
|
||||||
|
const UPDATE = ANamespace::ACTIVITY_SCHEMA . 'update';
|
||||||
|
/**
|
||||||
|
* Indicates that the actor has identified the presence of a target inside another object.
|
||||||
|
*
|
||||||
|
* @see http://activitystrea.ms/head/activity-schema.html#verbs
|
||||||
|
* @var string
|
||||||
|
*/
|
||||||
|
const TAG = ANamespace::ACTIVITY_SCHEMA . 'tag';
|
||||||
|
/**
|
||||||
|
* Indicates that the actor marked the object as an item of special interest.
|
||||||
|
*
|
||||||
|
* @see http://activitystrea.ms/head/activity-schema.html#verbs
|
||||||
|
* @var string
|
||||||
|
*/
|
||||||
|
const FAVORITE = ANamespace::ACTIVITY_SCHEMA . 'favorite';
|
||||||
|
/**
|
||||||
|
* Indicates that the actor has removed the object from the collection of favorited items.
|
||||||
|
*
|
||||||
|
* @see http://activitystrea.ms/head/activity-schema.html#verbs
|
||||||
|
* @var string
|
||||||
|
*/
|
||||||
|
const UNFAVORITE = ANamespace::ACTIVITY_SCHEMA . 'unfavorite';
|
||||||
|
/**
|
||||||
|
* Indicates that the actor has called out the object to readers.
|
||||||
|
*
|
||||||
|
* @see http://activitystrea.ms/head/activity-schema.html#verbs
|
||||||
|
* @var string
|
||||||
|
*/
|
||||||
|
const SHARE = ANamespace::ACTIVITY_SCHEMA . 'share';
|
||||||
|
/**
|
||||||
|
* Indicates that the actor has deleted the object.
|
||||||
|
*
|
||||||
|
* @see http://activitystrea.ms/head/activity-schema.html#verbs
|
||||||
|
* @var string
|
||||||
|
*/
|
||||||
|
const DELETE = ANamespace::ACTIVITY_SCHEMA . 'delete';
|
||||||
|
/**
|
||||||
|
* Indicates that the actor is calling the target's attention the object.
|
||||||
|
*
|
||||||
|
* @see https://www.w3.org/TR/activitystreams-vocabulary/#dfn-announce
|
||||||
|
* @var string
|
||||||
|
*/
|
||||||
|
const ANNOUNCE = ANamespace::ACTIVITY2 . 'Announce';
|
||||||
|
|
||||||
const POKE = ANamespace::ZOT . '/activity/poke';
|
/**
|
||||||
|
* Pokes an user.
|
||||||
|
*
|
||||||
|
* @see https://github.com/friendica/friendica/wiki/ActivityStreams#activity_poke
|
||||||
|
* @var string
|
||||||
|
*/
|
||||||
|
const POKE = ANamespace::ZOT . '/activity/poke';
|
||||||
|
|
||||||
const OBJ_BOOKMARK = ANamespace::ACTIVITY_SCHEMA . 'bookmark';
|
|
||||||
const OBJ_COMMENT = ANamespace::ACTIVITY_SCHEMA . 'comment';
|
|
||||||
const OBJ_NOTE = ANamespace::ACTIVITY_SCHEMA . 'note';
|
|
||||||
const OBJ_PERSON = ANamespace::ACTIVITY_SCHEMA . 'person';
|
|
||||||
const OBJ_IMAGE = ANamespace::ACTIVITY_SCHEMA . 'image';
|
|
||||||
const OBJ_PHOTO = ANamespace::ACTIVITY_SCHEMA . 'photo';
|
|
||||||
const OBJ_VIDEO = ANamespace::ACTIVITY_SCHEMA . 'video';
|
|
||||||
const OBJ_P_PHOTO = ANamespace::ACTIVITY_SCHEMA . 'profile-photo';
|
|
||||||
const OBJ_ALBUM = ANamespace::ACTIVITY_SCHEMA . 'photo-album';
|
|
||||||
const OBJ_EVENT = ANamespace::ACTIVITY_SCHEMA . 'event';
|
|
||||||
const OBJ_GROUP = ANamespace::ACTIVITY_SCHEMA . 'group';
|
|
||||||
const OBJ_TAGTERM = ANamespace::DFRN . '/tagterm';
|
|
||||||
const OBJ_PROFILE = ANamespace::DFRN . '/profile';
|
|
||||||
|
|
||||||
const OBJ_QUESTION = 'http://activityschema.org/object/question';
|
const O_UNFOLLOW = ANamespace::OSTATUS . '/unfollow';
|
||||||
|
const O_UNFAVOURITE = ANamespace::OSTATUS . '/unfavorite';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* likes (etc.) can apply to other things besides posts. Check if they are post children,
|
* likes (etc.) can apply to other things besides posts. Check if they are post children,
|
||||||
|
|
|
@ -7,21 +7,126 @@ namespace Friendica\Protocol\Activity;
|
||||||
*/
|
*/
|
||||||
final class ANamespace
|
final class ANamespace
|
||||||
{
|
{
|
||||||
|
/**
|
||||||
|
* Zot is a WebMTA which provides a decentralised identity and communications protocol using HTTPS/JSON.
|
||||||
|
*
|
||||||
|
* @var string
|
||||||
|
* @see https://zotlabs.org/page/zotlabs/specs+zot6+home
|
||||||
|
*/
|
||||||
const ZOT = 'http://purl.org/zot';
|
const ZOT = 'http://purl.org/zot';
|
||||||
|
/**
|
||||||
|
* Friendica is using ActivityStreams in version 1.0 for its activities and object types.
|
||||||
|
* Additional types are used for non standard activities.
|
||||||
|
*
|
||||||
|
* @var string
|
||||||
|
* @see https://github.com/friendica/friendica/wiki/ActivityStreams
|
||||||
|
*/
|
||||||
const DFRN = 'http://purl.org/macgirvin/dfrn/1.0';
|
const DFRN = 'http://purl.org/macgirvin/dfrn/1.0';
|
||||||
|
/**
|
||||||
|
* This namespace defines an extension for expressing threaded
|
||||||
|
* discussions within the Atom Syndication Format [RFC4287]
|
||||||
|
*
|
||||||
|
* @see https://tools.ietf.org/rfc/rfc4685.txt
|
||||||
|
* @var string
|
||||||
|
*/
|
||||||
const THREAD = 'http://purl.org/syndication/thread/1.0';
|
const THREAD = 'http://purl.org/syndication/thread/1.0';
|
||||||
|
/**
|
||||||
|
* This namespace adds mechanisms to the Atom Syndication Format
|
||||||
|
* that publishers of Atom Feed and Entry documents can use to
|
||||||
|
* explicitly identify Atom entries that have been removed.
|
||||||
|
*
|
||||||
|
* @see https://tools.ietf.org/html/rfc6721
|
||||||
|
* @var string
|
||||||
|
*/
|
||||||
const TOMB = 'http://purl.org/atompub/tombstones/1.0';
|
const TOMB = 'http://purl.org/atompub/tombstones/1.0';
|
||||||
|
/**
|
||||||
|
* This specification details a model for representing potential and completed activities
|
||||||
|
* using the JSON format.
|
||||||
|
*
|
||||||
|
* @see https://www.w3.org/ns/activitystreams
|
||||||
|
* @var string
|
||||||
|
*/
|
||||||
const ACTIVITY2 = 'https://www.w3.org/ns/activitystreams#';
|
const ACTIVITY2 = 'https://www.w3.org/ns/activitystreams#';
|
||||||
|
/**
|
||||||
|
* Atom Activities 1.0
|
||||||
|
*
|
||||||
|
* This namespace presents an XML format that allows activities on social objects
|
||||||
|
* to be expressed within the Atom Syndication Format.
|
||||||
|
*
|
||||||
|
* @see http://activitystrea.ms/spec/1.0
|
||||||
|
* @var string
|
||||||
|
*/
|
||||||
const ACTIVITY = 'http://activitystrea.ms/spec/1.0/';
|
const ACTIVITY = 'http://activitystrea.ms/spec/1.0/';
|
||||||
|
/**
|
||||||
|
* This namespace presents a base set of Object types and Verbs for use with Activity Streams.
|
||||||
|
*
|
||||||
|
* @see http://activitystrea.ms/head/activity-schema.html
|
||||||
|
* @var string
|
||||||
|
*/
|
||||||
const ACTIVITY_SCHEMA = 'http://activitystrea.ms/schema/1.0/';
|
const ACTIVITY_SCHEMA = 'http://activitystrea.ms/schema/1.0/';
|
||||||
|
/**
|
||||||
|
* Atom Media Extensions
|
||||||
|
*
|
||||||
|
* @var string
|
||||||
|
*/
|
||||||
const MEDIA = 'http://purl.org/syndication/atommedia';
|
const MEDIA = 'http://purl.org/syndication/atommedia';
|
||||||
|
/**
|
||||||
|
* The Salmon Protocol is an open, simple, standards-based solution that lets
|
||||||
|
* aggregators and sources unify the conversations.
|
||||||
|
*
|
||||||
|
* @see http://www.salmon-protocol.org/salmon-protocol-summary
|
||||||
|
* @var string
|
||||||
|
*/
|
||||||
const SALMON_ME = 'http://salmon-protocol.org/ns/magic-env';
|
const SALMON_ME = 'http://salmon-protocol.org/ns/magic-env';
|
||||||
|
/**
|
||||||
|
* OStatus is a minimal specification for distributed status updates or microblogging.
|
||||||
|
*
|
||||||
|
* @see https://ostatus.github.io/spec/OStatus%201.0%20Draft%202.html
|
||||||
|
* @var string
|
||||||
|
*/
|
||||||
const OSTATUSSUB = 'http://ostatus.org/schema/1.0/subscribe';
|
const OSTATUSSUB = 'http://ostatus.org/schema/1.0/subscribe';
|
||||||
|
/**
|
||||||
|
* GeoRSS was designed as a lightweight, community driven way to extend existing feeds with geographic information.
|
||||||
|
*
|
||||||
|
* @see http://www.georss.org/
|
||||||
|
* @var string
|
||||||
|
*/
|
||||||
const GEORSS = 'http://www.georss.org/georss';
|
const GEORSS = 'http://www.georss.org/georss';
|
||||||
|
/**
|
||||||
|
* The Portable Contacts specification is designed to make it easier for developers
|
||||||
|
* to give their users a secure way to access the address books and friends lists
|
||||||
|
* they have built up all over the web.
|
||||||
|
*
|
||||||
|
* @see http://portablecontacts.net/draft-spec/
|
||||||
|
* @var string
|
||||||
|
*/
|
||||||
const POCO = 'http://portablecontacts.net/spec/1.0';
|
const POCO = 'http://portablecontacts.net/spec/1.0';
|
||||||
|
/**
|
||||||
|
* @var string
|
||||||
|
*/
|
||||||
const FEED = 'http://schemas.google.com/g/2010#updates-from';
|
const FEED = 'http://schemas.google.com/g/2010#updates-from';
|
||||||
|
/**
|
||||||
|
* OStatus is a minimal specification for distributed status updates or microblogging.
|
||||||
|
*
|
||||||
|
* @see https://ostatus.github.io/spec/OStatus%201.0%20Draft%202.html
|
||||||
|
* @var string
|
||||||
|
*/
|
||||||
const OSTATUS = 'http://ostatus.org/schema/1.0';
|
const OSTATUS = 'http://ostatus.org/schema/1.0';
|
||||||
|
/**
|
||||||
|
* @var string
|
||||||
|
*/
|
||||||
const STATUSNET = 'http://status.net/schema/api/1/';
|
const STATUSNET = 'http://status.net/schema/api/1/';
|
||||||
|
/**
|
||||||
|
* This namespace describes the Atom Activity Streams in RDF Vocabulary (AAIR),
|
||||||
|
* defined as a dictionary of named properties and classes using W3C's RDF technology,
|
||||||
|
* and specifically a mapping of the Atom Activity Streams work to RDF.
|
||||||
|
*
|
||||||
|
* @see http://xmlns.notu.be/aair/#RFC4287
|
||||||
|
* @var string
|
||||||
|
*/
|
||||||
const ATOM1 = 'http://www.w3.org/2005/Atom';
|
const ATOM1 = 'http://www.w3.org/2005/Atom';
|
||||||
|
/**
|
||||||
|
* @var string
|
||||||
|
*/
|
||||||
const MASTODON = 'http://mastodon.social/schema/1.0';
|
const MASTODON = 'http://mastodon.social/schema/1.0';
|
||||||
}
|
}
|
||||||
|
|
103
src/Protocol/Activity/ObjectType.php
Normal file
103
src/Protocol/Activity/ObjectType.php
Normal file
|
@ -0,0 +1,103 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Friendica\Protocol\Activity;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* This class contains the different object types in activities
|
||||||
|
*/
|
||||||
|
final class ObjectType
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* The "bookmark" object type represents a pointer to some URL -- typically a web page.
|
||||||
|
*
|
||||||
|
* @see http://activitystrea.ms/head/activity-schema.html#bookmark
|
||||||
|
* @var string
|
||||||
|
*/
|
||||||
|
const BOOKMARK = ANamespace::ACTIVITY_SCHEMA . 'bookmark';
|
||||||
|
/**
|
||||||
|
* The "comment" object type represents a textual response to another object.
|
||||||
|
*
|
||||||
|
* @see http://activitystrea.ms/head/activity-schema.html#comment
|
||||||
|
* @var string
|
||||||
|
*/
|
||||||
|
const COMMENT = ANamespace::ACTIVITY_SCHEMA . 'comment';
|
||||||
|
/**
|
||||||
|
* The "comment" object type represents a textual response to another object.
|
||||||
|
* (Default type for items)
|
||||||
|
*
|
||||||
|
* @see http://activitystrea.ms/head/activity-schema.html#note
|
||||||
|
* @var string
|
||||||
|
*/
|
||||||
|
const NOTE = ANamespace::ACTIVITY_SCHEMA . 'note';
|
||||||
|
/**
|
||||||
|
* The "person" object type represents a user account.
|
||||||
|
*
|
||||||
|
* @see http://activitystrea.ms/head/activity-schema.html#person
|
||||||
|
* @var string
|
||||||
|
*/
|
||||||
|
const PERSON = ANamespace::ACTIVITY_SCHEMA . 'person';
|
||||||
|
/**
|
||||||
|
* The "image" object type represents a graphical image.
|
||||||
|
*
|
||||||
|
* @see http://activitystrea.ms/head/activity-schema.html#image
|
||||||
|
* @var string
|
||||||
|
*/
|
||||||
|
const IMAGE = ANamespace::ACTIVITY_SCHEMA . 'image';
|
||||||
|
/**
|
||||||
|
* @var string
|
||||||
|
*/
|
||||||
|
const PHOTO = ANamespace::ACTIVITY_SCHEMA . 'photo';
|
||||||
|
/**
|
||||||
|
* The "video" object type represents video content,
|
||||||
|
* which usually consists of a motion picture track and an audio track.
|
||||||
|
*
|
||||||
|
* @see http://activitystrea.ms/head/activity-schema.html#video
|
||||||
|
* @var string
|
||||||
|
*/
|
||||||
|
const VIDEO = ANamespace::ACTIVITY_SCHEMA . 'video';
|
||||||
|
/**
|
||||||
|
* @var string
|
||||||
|
*/
|
||||||
|
const PROFILE_PHOTO = ANamespace::ACTIVITY_SCHEMA . 'profile-photo';
|
||||||
|
/**
|
||||||
|
* @var string
|
||||||
|
*/
|
||||||
|
const ALBUM = ANamespace::ACTIVITY_SCHEMA . 'photo-album';
|
||||||
|
/**
|
||||||
|
* The "event" object type represents an event that occurs in a certain place during a particular interval of time.
|
||||||
|
*
|
||||||
|
* @see http://activitystrea.ms/head/activity-schema.html#event
|
||||||
|
* @var string
|
||||||
|
*/
|
||||||
|
const EVENT = ANamespace::ACTIVITY_SCHEMA . 'event';
|
||||||
|
/**
|
||||||
|
* The "group" object type represents a grouping of objects in which member objects can join or leave.
|
||||||
|
*
|
||||||
|
* @see http://activitystrea.ms/head/activity-schema.html#group
|
||||||
|
* @var string
|
||||||
|
*/
|
||||||
|
const GROUP = ANamespace::ACTIVITY_SCHEMA . 'group';
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @var string
|
||||||
|
*/
|
||||||
|
const HEART = ANamespace::DFRN . '/heart';
|
||||||
|
/**
|
||||||
|
* @var string
|
||||||
|
*/
|
||||||
|
const TAGTERM = ANamespace::DFRN . '/tagterm';
|
||||||
|
/**
|
||||||
|
* @var string
|
||||||
|
*/
|
||||||
|
const PROFILE = ANamespace::DFRN . '/profile';
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The "question" object type represents a question or poll.
|
||||||
|
*
|
||||||
|
* @see http://activitystrea.ms/head/activity-schema.html#question
|
||||||
|
* @var string
|
||||||
|
*/
|
||||||
|
const QUESTION = 'http://activityschema.org/object/question';
|
||||||
|
}
|
|
@ -4,20 +4,20 @@
|
||||||
*/
|
*/
|
||||||
namespace Friendica\Protocol\ActivityPub;
|
namespace Friendica\Protocol\ActivityPub;
|
||||||
|
|
||||||
use Friendica\Database\DBA;
|
|
||||||
use Friendica\Content\Text\BBCode;
|
use Friendica\Content\Text\BBCode;
|
||||||
use Friendica\Content\Text\HTML;
|
use Friendica\Content\Text\HTML;
|
||||||
use Friendica\Core\Config;
|
use Friendica\Core\Config;
|
||||||
use Friendica\Core\PConfig;
|
|
||||||
use Friendica\Core\Logger;
|
use Friendica\Core\Logger;
|
||||||
|
use Friendica\Core\PConfig;
|
||||||
use Friendica\Core\Protocol;
|
use Friendica\Core\Protocol;
|
||||||
use Friendica\Model\Contact;
|
use Friendica\Database\DBA;
|
||||||
use Friendica\Model\APContact;
|
use Friendica\Model\APContact;
|
||||||
use Friendica\Model\Item;
|
use Friendica\Model\Contact;
|
||||||
use Friendica\Model\Event;
|
use Friendica\Model\Event;
|
||||||
|
use Friendica\Model\Item;
|
||||||
|
use Friendica\Model\Mail;
|
||||||
use Friendica\Model\Term;
|
use Friendica\Model\Term;
|
||||||
use Friendica\Model\User;
|
use Friendica\Model\User;
|
||||||
use Friendica\Model\Mail;
|
|
||||||
use Friendica\Protocol\Activity;
|
use Friendica\Protocol\Activity;
|
||||||
use Friendica\Protocol\ActivityPub;
|
use Friendica\Protocol\ActivityPub;
|
||||||
use Friendica\Util\DateTimeFormat;
|
use Friendica\Util\DateTimeFormat;
|
||||||
|
@ -173,10 +173,10 @@ class Processor
|
||||||
|
|
||||||
if ($activity['reply-to-id'] == $activity['id']) {
|
if ($activity['reply-to-id'] == $activity['id']) {
|
||||||
$item['gravity'] = GRAVITY_PARENT;
|
$item['gravity'] = GRAVITY_PARENT;
|
||||||
$item['object-type'] = Activity::OBJ_NOTE;
|
$item['object-type'] = Activity\ObjectType::NOTE;
|
||||||
} else {
|
} else {
|
||||||
$item['gravity'] = GRAVITY_COMMENT;
|
$item['gravity'] = GRAVITY_COMMENT;
|
||||||
$item['object-type'] = Activity::OBJ_COMMENT;
|
$item['object-type'] = Activity\ObjectType::COMMENT;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (empty($activity['directmessage']) && ($activity['id'] != $activity['reply-to-id']) && !Item::exists(['uri' => $activity['reply-to-id']])) {
|
if (empty($activity['directmessage']) && ($activity['id'] != $activity['reply-to-id']) && !Item::exists(['uri' => $activity['reply-to-id']])) {
|
||||||
|
@ -255,7 +255,7 @@ class Processor
|
||||||
$item['verb'] = $verb;
|
$item['verb'] = $verb;
|
||||||
$item['thr-parent'] = $activity['object_id'];
|
$item['thr-parent'] = $activity['object_id'];
|
||||||
$item['gravity'] = GRAVITY_ACTIVITY;
|
$item['gravity'] = GRAVITY_ACTIVITY;
|
||||||
$item['object-type'] = Activity::OBJ_NOTE;
|
$item['object-type'] = Activity\ObjectType::NOTE;
|
||||||
|
|
||||||
$item['diaspora_signed_text'] = $activity['diaspora:like'] ?? '';
|
$item['diaspora_signed_text'] = $activity['diaspora:like'] ?? '';
|
||||||
|
|
||||||
|
|
|
@ -1078,9 +1078,9 @@ class DFRN
|
||||||
if ($item['object-type'] != "") {
|
if ($item['object-type'] != "") {
|
||||||
XML::addElement($doc, $entry, "activity:object-type", $item['object-type']);
|
XML::addElement($doc, $entry, "activity:object-type", $item['object-type']);
|
||||||
} elseif ($item['id'] == $item['parent']) {
|
} elseif ($item['id'] == $item['parent']) {
|
||||||
XML::addElement($doc, $entry, "activity:object-type", Activity::OBJ_NOTE);
|
XML::addElement($doc, $entry, "activity:object-type", Activity\ObjectType::NOTE);
|
||||||
} else {
|
} else {
|
||||||
XML::addElement($doc, $entry, "activity:object-type", Activity::OBJ_COMMENT);
|
XML::addElement($doc, $entry, "activity:object-type", Activity\ObjectType::COMMENT);
|
||||||
}
|
}
|
||||||
|
|
||||||
$actobj = self::createActivity($doc, "activity:object", $item['object']);
|
$actobj = self::createActivity($doc, "activity:object", $item['object']);
|
||||||
|
@ -1123,7 +1123,7 @@ class DFRN
|
||||||
"link",
|
"link",
|
||||||
"",
|
"",
|
||||||
["rel" => "mentioned",
|
["rel" => "mentioned",
|
||||||
"ostatus:object-type" => Activity::OBJ_GROUP,
|
"ostatus:object-type" => Activity\ObjectType::GROUP,
|
||||||
"href" => $mention]
|
"href" => $mention]
|
||||||
);
|
);
|
||||||
} else {
|
} else {
|
||||||
|
@ -1133,7 +1133,7 @@ class DFRN
|
||||||
"link",
|
"link",
|
||||||
"",
|
"",
|
||||||
["rel" => "mentioned",
|
["rel" => "mentioned",
|
||||||
"ostatus:object-type" => Activity::OBJ_PERSON,
|
"ostatus:object-type" => Activity\ObjectType::PERSON,
|
||||||
"href" => $mention]
|
"href" => $mention]
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
@ -2116,7 +2116,7 @@ class DFRN
|
||||||
}
|
}
|
||||||
$xo = XML::parseString($item["object"], false);
|
$xo = XML::parseString($item["object"], false);
|
||||||
|
|
||||||
if (($xo->type == Activity::OBJ_PERSON) && ($xo->id)) {
|
if (($xo->type == Activity\ObjectType::PERSON) && ($xo->id)) {
|
||||||
// somebody was poked/prodded. Was it me?
|
// somebody was poked/prodded. Was it me?
|
||||||
$Blink = '';
|
$Blink = '';
|
||||||
foreach ($xo->link as $l) {
|
foreach ($xo->link as $l) {
|
||||||
|
@ -2237,11 +2237,11 @@ class DFRN
|
||||||
$is_like = false;
|
$is_like = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (($item["verb"] == Activity::TAG) && ($item["object-type"] == Activity::OBJ_TAGTERM)) {
|
if (($item["verb"] == Activity::TAG) && ($item["object-type"] == Activity\ObjectType::TAGTERM)) {
|
||||||
$xo = XML::parseString($item["object"], false);
|
$xo = XML::parseString($item["object"], false);
|
||||||
$xt = XML::parseString($item["target"], false);
|
$xt = XML::parseString($item["target"], false);
|
||||||
|
|
||||||
if ($xt->type == Activity::OBJ_NOTE) {
|
if ($xt->type == Activity\ObjectType::NOTE) {
|
||||||
$item_tag = Item::selectFirst(['id', 'tag'], ['uri' => $xt->id, 'uid' => $importer["importer_uid"]]);
|
$item_tag = Item::selectFirst(['id', 'tag'], ['uri' => $xt->id, 'uid' => $importer["importer_uid"]]);
|
||||||
|
|
||||||
if (!DBA::isResult($item_tag)) {
|
if (!DBA::isResult($item_tag)) {
|
||||||
|
@ -2516,7 +2516,7 @@ class DFRN
|
||||||
// Now assign the rest of the values that depend on the type of the message
|
// Now assign the rest of the values that depend on the type of the message
|
||||||
if (in_array($entrytype, [DFRN::REPLY, DFRN::REPLY_RC])) {
|
if (in_array($entrytype, [DFRN::REPLY, DFRN::REPLY_RC])) {
|
||||||
if (!isset($item["object-type"])) {
|
if (!isset($item["object-type"])) {
|
||||||
$item["object-type"] = Activity::OBJ_COMMENT;
|
$item["object-type"] = Activity\ObjectType::COMMENT;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($item["contact-id"] != $owner["contact-id"]) {
|
if ($item["contact-id"] != $owner["contact-id"]) {
|
||||||
|
@ -2540,11 +2540,11 @@ class DFRN
|
||||||
$item["wall"] = 1;
|
$item["wall"] = 1;
|
||||||
} elseif ($entrytype == DFRN::TOP_LEVEL) {
|
} elseif ($entrytype == DFRN::TOP_LEVEL) {
|
||||||
if (!isset($item["object-type"])) {
|
if (!isset($item["object-type"])) {
|
||||||
$item["object-type"] = Activity::OBJ_NOTE;
|
$item["object-type"] = Activity\ObjectType::NOTE;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Is it an event?
|
// Is it an event?
|
||||||
if (($item["object-type"] == Activity::OBJ_EVENT) && !$owner_unknown) {
|
if (($item["object-type"] == Activity\ObjectType::EVENT) && !$owner_unknown) {
|
||||||
Logger::log("Item ".$item["uri"]." seems to contain an event.", Logger::DEBUG);
|
Logger::log("Item ".$item["uri"]." seems to contain an event.", Logger::DEBUG);
|
||||||
$ev = Event::fromBBCode($item["body"]);
|
$ev = Event::fromBBCode($item["body"]);
|
||||||
if ((!empty($ev['desc']) || !empty($ev['summary'])) && !empty($ev['start'])) {
|
if ((!empty($ev['desc']) || !empty($ev['summary'])) && !empty($ev['start'])) {
|
||||||
|
|
|
@ -1855,7 +1855,7 @@ class Diaspora
|
||||||
$datarray["parent-uri"] = $parent_item["uri"];
|
$datarray["parent-uri"] = $parent_item["uri"];
|
||||||
}
|
}
|
||||||
|
|
||||||
$datarray["object-type"] = Activity::OBJ_COMMENT;
|
$datarray["object-type"] = Activity\ObjectType::COMMENT;
|
||||||
|
|
||||||
$datarray["protocol"] = Conversation::PARCEL_DIASPORA;
|
$datarray["protocol"] = Conversation::PARCEL_DIASPORA;
|
||||||
$datarray["source"] = $xml;
|
$datarray["source"] = $xml;
|
||||||
|
@ -2086,7 +2086,7 @@ class Diaspora
|
||||||
$datarray["gravity"] = GRAVITY_ACTIVITY;
|
$datarray["gravity"] = GRAVITY_ACTIVITY;
|
||||||
$datarray["parent-uri"] = $parent_item["uri"];
|
$datarray["parent-uri"] = $parent_item["uri"];
|
||||||
|
|
||||||
$datarray["object-type"] = Activity::OBJ_NOTE;
|
$datarray["object-type"] = Activity\ObjectType::NOTE;
|
||||||
|
|
||||||
$datarray["body"] = $verb;
|
$datarray["body"] = $verb;
|
||||||
|
|
||||||
|
@ -2687,7 +2687,7 @@ class Diaspora
|
||||||
|
|
||||||
$datarray['verb'] = $datarray['body'] = Activity::ANNOUNCE;
|
$datarray['verb'] = $datarray['body'] = Activity::ANNOUNCE;
|
||||||
$datarray['gravity'] = GRAVITY_ACTIVITY;
|
$datarray['gravity'] = GRAVITY_ACTIVITY;
|
||||||
$datarray['object-type'] = Activity::OBJ_NOTE;
|
$datarray['object-type'] = Activity\ObjectType::NOTE;
|
||||||
|
|
||||||
$datarray['protocol'] = $item['protocol'];
|
$datarray['protocol'] = $item['protocol'];
|
||||||
|
|
||||||
|
@ -2963,9 +2963,9 @@ class Diaspora
|
||||||
XML::unescape($photo->remote_photo_name)."[/img]\n".$body;
|
XML::unescape($photo->remote_photo_name)."[/img]\n".$body;
|
||||||
}
|
}
|
||||||
|
|
||||||
$datarray["object-type"] = Activity::OBJ_IMAGE;
|
$datarray["object-type"] = Activity\ObjectType::IMAGE;
|
||||||
} else {
|
} else {
|
||||||
$datarray["object-type"] = Activity::OBJ_NOTE;
|
$datarray["object-type"] = Activity\ObjectType::NOTE;
|
||||||
|
|
||||||
// Add OEmbed and other information to the body
|
// Add OEmbed and other information to the body
|
||||||
if (!self::isRedmatrix($contact["url"])) {
|
if (!self::isRedmatrix($contact["url"])) {
|
||||||
|
|
|
@ -200,7 +200,7 @@ class Feed {
|
||||||
$header["gravity"] = GRAVITY_PARENT;
|
$header["gravity"] = GRAVITY_PARENT;
|
||||||
$header["private"] = 2;
|
$header["private"] = 2;
|
||||||
$header["verb"] = Activity::POST;
|
$header["verb"] = Activity::POST;
|
||||||
$header["object-type"] = Activity::OBJ_NOTE;
|
$header["object-type"] = Activity\ObjectType::NOTE;
|
||||||
|
|
||||||
$header["contact-id"] = $contact["id"];
|
$header["contact-id"] = $contact["id"];
|
||||||
|
|
||||||
|
@ -421,7 +421,7 @@ class Feed {
|
||||||
$item["title"] = "";
|
$item["title"] = "";
|
||||||
$item["body"] = $item["body"].add_page_info($item["plink"], false, $preview, ($contact["fetch_further_information"] == 2), $contact["ffi_keyword_blacklist"]);
|
$item["body"] = $item["body"].add_page_info($item["plink"], false, $preview, ($contact["fetch_further_information"] == 2), $contact["ffi_keyword_blacklist"]);
|
||||||
$item["tag"] = add_page_keywords($item["plink"], $preview, ($contact["fetch_further_information"] == 2), $contact["ffi_keyword_blacklist"]);
|
$item["tag"] = add_page_keywords($item["plink"], $preview, ($contact["fetch_further_information"] == 2), $contact["ffi_keyword_blacklist"]);
|
||||||
$item["object-type"] = Activity::OBJ_BOOKMARK;
|
$item["object-type"] = Activity\ObjectType::BOOKMARK;
|
||||||
unset($item["attach"]);
|
unset($item["attach"]);
|
||||||
} else {
|
} else {
|
||||||
if (!empty($summary)) {
|
if (!empty($summary)) {
|
||||||
|
|
|
@ -434,7 +434,7 @@ class OStatus
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (in_array($item["verb"], [ANamespace::OSTATUS . "/unfavorite", Activity::UNFAVORITE])) {
|
if (in_array($item["verb"], [Activity::O_UNFAVOURITE, Activity::UNFAVORITE])) {
|
||||||
// Ignore "Unfavorite" message
|
// Ignore "Unfavorite" message
|
||||||
Logger::log("Ignore unfavorite message ".print_r($item, true), Logger::DEBUG);
|
Logger::log("Ignore unfavorite message ".print_r($item, true), Logger::DEBUG);
|
||||||
continue;
|
continue;
|
||||||
|
@ -465,7 +465,7 @@ class OStatus
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($item["verb"] == ANamespace::OSTATUS . "/unfollow") {
|
if ($item["verb"] == Activity::O_UNFOLLOW) {
|
||||||
$dummy = null;
|
$dummy = null;
|
||||||
Contact::removeFollower($importer, $contact, $item, $dummy);
|
Contact::removeFollower($importer, $contact, $item, $dummy);
|
||||||
continue;
|
continue;
|
||||||
|
@ -478,7 +478,7 @@ class OStatus
|
||||||
$item["verb"] = Activity::LIKE;
|
$item["verb"] = Activity::LIKE;
|
||||||
$item["parent-uri"] = $orig_uri;
|
$item["parent-uri"] = $orig_uri;
|
||||||
$item["gravity"] = GRAVITY_ACTIVITY;
|
$item["gravity"] = GRAVITY_ACTIVITY;
|
||||||
$item["object-type"] = Activity::OBJ_NOTE;
|
$item["object-type"] = Activity\ObjectType::NOTE;
|
||||||
}
|
}
|
||||||
|
|
||||||
// http://activitystrea.ms/schema/1.0/rsvp-yes
|
// http://activitystrea.ms/schema/1.0/rsvp-yes
|
||||||
|
@ -593,10 +593,10 @@ class OStatus
|
||||||
{
|
{
|
||||||
$item["body"] = HTML::toBBCode(XML::getFirstNodeValue($xpath, 'atom:content/text()', $entry));
|
$item["body"] = HTML::toBBCode(XML::getFirstNodeValue($xpath, 'atom:content/text()', $entry));
|
||||||
$item["object-type"] = XML::getFirstNodeValue($xpath, 'activity:object-type/text()', $entry);
|
$item["object-type"] = XML::getFirstNodeValue($xpath, 'activity:object-type/text()', $entry);
|
||||||
if (($item["object-type"] == Activity::OBJ_BOOKMARK) || ($item["object-type"] == Activity::OBJ_EVENT)) {
|
if (($item["object-type"] == Activity\ObjectType::BOOKMARK) || ($item["object-type"] == Activity\ObjectType::EVENT)) {
|
||||||
$item["title"] = XML::getFirstNodeValue($xpath, 'atom:title/text()', $entry);
|
$item["title"] = XML::getFirstNodeValue($xpath, 'atom:title/text()', $entry);
|
||||||
$item["body"] = XML::getFirstNodeValue($xpath, 'atom:summary/text()', $entry);
|
$item["body"] = XML::getFirstNodeValue($xpath, 'atom:summary/text()', $entry);
|
||||||
} elseif ($item["object-type"] == Activity::OBJ_QUESTION) {
|
} elseif ($item["object-type"] == Activity\ObjectType::QUESTION) {
|
||||||
$item["title"] = XML::getFirstNodeValue($xpath, 'atom:title/text()', $entry);
|
$item["title"] = XML::getFirstNodeValue($xpath, 'atom:title/text()', $entry);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1106,8 +1106,8 @@ class OStatus
|
||||||
switch ($attribute['rel']) {
|
switch ($attribute['rel']) {
|
||||||
case "alternate":
|
case "alternate":
|
||||||
$item["plink"] = $attribute['href'];
|
$item["plink"] = $attribute['href'];
|
||||||
if (($item["object-type"] == Activity::OBJ_QUESTION)
|
if (($item["object-type"] == Activity\ObjectType::QUESTION)
|
||||||
|| ($item["object-type"] == Activity::OBJ_EVENT)
|
|| ($item["object-type"] == Activity\ObjectType::EVENT)
|
||||||
) {
|
) {
|
||||||
$item["body"] .= add_page_info($attribute['href']);
|
$item["body"] .= add_page_info($attribute['href']);
|
||||||
}
|
}
|
||||||
|
@ -1136,7 +1136,7 @@ class OStatus
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case "related":
|
case "related":
|
||||||
if ($item["object-type"] != Activity::OBJ_BOOKMARK) {
|
if ($item["object-type"] != Activity\ObjectType::BOOKMARK) {
|
||||||
if (!isset($item["parent-uri"])) {
|
if (!isset($item["parent-uri"])) {
|
||||||
$item["parent-uri"] = $attribute['href'];
|
$item["parent-uri"] = $attribute['href'];
|
||||||
}
|
}
|
||||||
|
@ -1462,9 +1462,9 @@ class OStatus
|
||||||
$author = $doc->createElement("author");
|
$author = $doc->createElement("author");
|
||||||
XML::addElement($doc, $author, "id", $owner["url"]);
|
XML::addElement($doc, $author, "id", $owner["url"]);
|
||||||
if ($owner['account-type'] == User::ACCOUNT_TYPE_COMMUNITY) {
|
if ($owner['account-type'] == User::ACCOUNT_TYPE_COMMUNITY) {
|
||||||
XML::addElement($doc, $author, "activity:object-type", Activity::OBJ_GROUP);
|
XML::addElement($doc, $author, "activity:object-type", Activity\ObjectType::GROUP);
|
||||||
} else {
|
} else {
|
||||||
XML::addElement($doc, $author, "activity:object-type", Activity::OBJ_PERSON);
|
XML::addElement($doc, $author, "activity:object-type", Activity\ObjectType::PERSON);
|
||||||
}
|
}
|
||||||
XML::addElement($doc, $author, "uri", $owner["url"]);
|
XML::addElement($doc, $author, "uri", $owner["url"]);
|
||||||
XML::addElement($doc, $author, "name", $owner["nick"]);
|
XML::addElement($doc, $author, "name", $owner["nick"]);
|
||||||
|
@ -1557,11 +1557,11 @@ class OStatus
|
||||||
*/
|
*/
|
||||||
private static function constructObjecttype(array $item)
|
private static function constructObjecttype(array $item)
|
||||||
{
|
{
|
||||||
if (!empty($item['object-type']) && in_array($item['object-type'], [Activity::OBJ_NOTE, Activity::OBJ_COMMENT])) {
|
if (!empty($item['object-type']) && in_array($item['object-type'], [Activity\ObjectType::NOTE, Activity\ObjectType::COMMENT])) {
|
||||||
return $item['object-type'];
|
return $item['object-type'];
|
||||||
}
|
}
|
||||||
|
|
||||||
return Activity::OBJ_NOTE;
|
return Activity\ObjectType::NOTE;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -1592,7 +1592,7 @@ class OStatus
|
||||||
|
|
||||||
if ($item["verb"] == Activity::LIKE) {
|
if ($item["verb"] == Activity::LIKE) {
|
||||||
return self::likeEntry($doc, $item, $owner, $toplevel);
|
return self::likeEntry($doc, $item, $owner, $toplevel);
|
||||||
} elseif (in_array($item["verb"], [Activity::FOLLOW, ANamespace::OSTATUS . "/unfollow"])) {
|
} elseif (in_array($item["verb"], [Activity::FOLLOW, Activity::O_UNFOLLOW])) {
|
||||||
return self::followEntry($doc, $item, $owner, $toplevel);
|
return self::followEntry($doc, $item, $owner, $toplevel);
|
||||||
} else {
|
} else {
|
||||||
return self::noteEntry($doc, $item, $owner, $toplevel, $feed_mode);
|
return self::noteEntry($doc, $item, $owner, $toplevel, $feed_mode);
|
||||||
|
@ -1791,7 +1791,7 @@ class OStatus
|
||||||
private static function addPersonObject(DOMDocument $doc, array $owner, array $contact)
|
private static function addPersonObject(DOMDocument $doc, array $owner, array $contact)
|
||||||
{
|
{
|
||||||
$object = $doc->createElement("activity:object");
|
$object = $doc->createElement("activity:object");
|
||||||
XML::addElement($doc, $object, "activity:object-type", Activity::OBJ_PERSON);
|
XML::addElement($doc, $object, "activity:object-type", Activity\ObjectType::PERSON);
|
||||||
|
|
||||||
if ($contact['network'] == Protocol::PHANTOM) {
|
if ($contact['network'] == Protocol::PHANTOM) {
|
||||||
XML::addElement($doc, $object, "id", $contact['url']);
|
XML::addElement($doc, $object, "id", $contact['url']);
|
||||||
|
@ -1919,7 +1919,7 @@ class OStatus
|
||||||
|
|
||||||
$entry = self::entryHeader($doc, $owner, $item, $toplevel);
|
$entry = self::entryHeader($doc, $owner, $item, $toplevel);
|
||||||
|
|
||||||
XML::addElement($doc, $entry, "activity:object-type", Activity::OBJ_NOTE);
|
XML::addElement($doc, $entry, "activity:object-type", Activity\ObjectType::NOTE);
|
||||||
|
|
||||||
self::entryContent($doc, $entry, $item, $owner, $title, '', true, $feed_mode);
|
self::entryContent($doc, $entry, $item, $owner, $title, '', true, $feed_mode);
|
||||||
|
|
||||||
|
@ -2112,14 +2112,14 @@ class OStatus
|
||||||
XML::addElement($doc, $entry, "link", "",
|
XML::addElement($doc, $entry, "link", "",
|
||||||
[
|
[
|
||||||
"rel" => "mentioned",
|
"rel" => "mentioned",
|
||||||
"ostatus:object-type" => Activity::OBJ_GROUP,
|
"ostatus:object-type" => Activity\ObjectType::GROUP,
|
||||||
"href" => $mention]
|
"href" => $mention]
|
||||||
);
|
);
|
||||||
} else {
|
} else {
|
||||||
XML::addElement($doc, $entry, "link", "",
|
XML::addElement($doc, $entry, "link", "",
|
||||||
[
|
[
|
||||||
"rel" => "mentioned",
|
"rel" => "mentioned",
|
||||||
"ostatus:object-type" => Activity::OBJ_PERSON,
|
"ostatus:object-type" => Activity\ObjectType::PERSON,
|
||||||
"href" => $mention]
|
"href" => $mention]
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
@ -2232,7 +2232,7 @@ class OStatus
|
||||||
|
|
||||||
if ($filter === 'comments') {
|
if ($filter === 'comments') {
|
||||||
$condition[0] .= " AND `object-type` = ? ";
|
$condition[0] .= " AND `object-type` = ? ";
|
||||||
$condition[] = Activity::OBJ_COMMENT;
|
$condition[] = Activity\ObjectType::COMMENT;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($owner['account-type'] != User::ACCOUNT_TYPE_COMMUNITY) {
|
if ($owner['account-type'] != User::ACCOUNT_TYPE_COMMUNITY) {
|
||||||
|
|
|
@ -495,7 +495,7 @@ class OnePoll
|
||||||
|
|
||||||
$datarray = [];
|
$datarray = [];
|
||||||
$datarray['verb'] = Activity::POST;
|
$datarray['verb'] = Activity::POST;
|
||||||
$datarray['object-type'] = Activity::OBJ_NOTE;
|
$datarray['object-type'] = Activity\ObjectType::NOTE;
|
||||||
$datarray['network'] = Protocol::MAIL;
|
$datarray['network'] = Protocol::MAIL;
|
||||||
// $meta = Email::messageMeta($mbox, $msg_uid);
|
// $meta = Email::messageMeta($mbox, $msg_uid);
|
||||||
|
|
||||||
|
|
|
@ -16,13 +16,13 @@ class ActivityTest extends MockedTest
|
||||||
'assert' => true,
|
'assert' => true,
|
||||||
],
|
],
|
||||||
'simple' => [
|
'simple' => [
|
||||||
'haystack' => Activity::OBJ_TAGTERM,
|
'haystack' => Activity\ObjectType::TAGTERM,
|
||||||
'needle' => Activity::OBJ_TAGTERM,
|
'needle' => Activity\ObjectType::TAGTERM,
|
||||||
'assert' => true,
|
'assert' => true,
|
||||||
],
|
],
|
||||||
'withNamespace' => [
|
'withNamespace' => [
|
||||||
'haystack' => 'tagterm',
|
'haystack' => 'tagterm',
|
||||||
'needle' => Activity\ANamespace::ACTIVITY_SCHEMA . Activity::OBJ_TAGTERM,
|
'needle' => Activity\ANamespace::ACTIVITY_SCHEMA . Activity\ObjectType::TAGTERM,
|
||||||
'assert' => true,
|
'assert' => true,
|
||||||
],
|
],
|
||||||
'invalidSimple' => [
|
'invalidSimple' => [
|
||||||
|
@ -32,12 +32,12 @@ class ActivityTest extends MockedTest
|
||||||
],
|
],
|
||||||
'invalidWithOutNamespace' => [
|
'invalidWithOutNamespace' => [
|
||||||
'haystack' => 'tagterm',
|
'haystack' => 'tagterm',
|
||||||
'needle' => Activity::OBJ_TAGTERM,
|
'needle' => Activity\ObjectType::TAGTERM,
|
||||||
'assert' => false,
|
'assert' => false,
|
||||||
],
|
],
|
||||||
'withSubPath' => [
|
'withSubPath' => [
|
||||||
'haystack' => 'tagterm',
|
'haystack' => 'tagterm',
|
||||||
'needle' => Activity\ANamespace::ACTIVITY_SCHEMA . '/bla/' . Activity::OBJ_TAGTERM,
|
'needle' => Activity\ANamespace::ACTIVITY_SCHEMA . '/bla/' . Activity\ObjectType::TAGTERM,
|
||||||
'assert' => true,
|
'assert' => true,
|
||||||
],
|
],
|
||||||
];
|
];
|
||||||
|
@ -60,6 +60,6 @@ class ActivityTest extends MockedTest
|
||||||
$activity = new Activity();
|
$activity = new Activity();
|
||||||
|
|
||||||
$this->assertTrue($activity->isHidden(Activity::LIKE));
|
$this->assertTrue($activity->isHidden(Activity::LIKE));
|
||||||
$this->assertFalse($activity->isHidden(Activity::OBJ_BOOKMARK));
|
$this->assertFalse($activity->isHidden(Activity\ObjectType::BOOKMARK));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue