1
1
Fork 0

Several improvements

This commit is contained in:
Michael 2018-09-15 07:40:19 +00:00
parent fb5b6e4a14
commit 957c70d1c6

View file

@ -136,7 +136,7 @@ class ActivityPub
'toot' => 'http://joinmastodon.org/ns#']]]; 'toot' => 'http://joinmastodon.org/ns#']]];
$data['type'] = 'Create'; $data['type'] = 'Create';
$data['id'] = $item['plink']; $data['id'] = $item['uri'];
$data['actor'] = $item['author-link']; $data['actor'] = $item['author-link'];
$data['to'] = 'https://www.w3.org/ns/activitystreams#Public'; $data['to'] = 'https://www.w3.org/ns/activitystreams#Public';
$data['object'] = self::createNote($item); $data['object'] = self::createNote($item);
@ -147,18 +147,31 @@ class ActivityPub
{ {
$data = []; $data = [];
$data['type'] = 'Note'; $data['type'] = 'Note';
$data['id'] = $item['plink']; $data['id'] = $item['uri'];
//$data['context'] = $data['conversation'] = $item['parent-uri'];
if ($item['uri'] != $item['thr-parent']) {
$data['inReplyTo'] = $item['thr-parent'];
}
$conversation = DBA::selectFirst('conversation', ['conversation-uri'], ['item-uri' => $item['parent-uri']]);
if (DBA::isResult($conversation) && !empty($conversation['conversation-uri'])) {
$conversation_uri = $conversation['conversation-uri'];
} else {
$conversation_uri = $item['parent-uri'];
}
$data['context'] = $data['conversation'] = $conversation_uri;
$data['actor'] = $item['author-link']; $data['actor'] = $item['author-link'];
$data['to'] = []; $data['to'] = [];
if (!$item['private']) { if (!$item['private']) {
$data['to'][] = '"https://pleroma.soykaf.com/users/heluecht"'; $data['to'][] = 'https://www.w3.org/ns/activitystreams#Public';
} }
$data['published'] = DateTimeFormat::utc($item["created"]."+00:00", DateTimeFormat::ATOM); $data['published'] = DateTimeFormat::utc($item["created"]."+00:00", DateTimeFormat::ATOM);
$data['updated'] = DateTimeFormat::utc($item["edited"]."+00:00", DateTimeFormat::ATOM); $data['updated'] = DateTimeFormat::utc($item["edited"]."+00:00", DateTimeFormat::ATOM);
$data['attributedTo'] = $item['author-link']; $data['attributedTo'] = $item['author-link'];
$data['name'] = BBCode::convert($item['title'], false, 7); $data['name'] = BBCode::convert($item['title'], false, 7);
$data['content'] = BBCode::convert($item['body'], false, 7); $data['content'] = BBCode::convert($item['body'], false, 7);
$data['source'] = ['content' => $item['body'], 'mediaType' => "text/bbcode"];
//$data['summary'] = ''; // Ignore by now //$data['summary'] = ''; // Ignore by now
//$data['sensitive'] = false; // - Query NSFW //$data['sensitive'] = false; // - Query NSFW
//$data['emoji'] = []; // Ignore by now //$data['emoji'] = []; // Ignore by now
@ -548,12 +561,6 @@ class ActivityPub
return; return;
} }
$receivers = self::getReceivers($activity);
if (empty($receivers)) {
logger('No receivers found', LOGGER_DEBUG);
return;
}
// ---------------------------------- // ----------------------------------
/* /*
// unhandled // unhandled
@ -573,12 +580,19 @@ class ActivityPub
*/ */
if (!in_array($activity['type'], ['Like', 'Dislike'])) { if (!in_array($activity['type'], ['Like', 'Dislike'])) {
$receivers = self::getReceivers($activity);
if (empty($receivers)) {
logger('No receivers found', LOGGER_DEBUG);
return;
}
$item = self::fetchObject($object_url, $activity['object']); $item = self::fetchObject($object_url, $activity['object']);
if (empty($item)) { if (empty($item)) {
logger("Object data couldn't be processed", LOGGER_DEBUG); logger("Object data couldn't be processed", LOGGER_DEBUG);
return; return;
} }
} else { } else {
$receivers = [];
$item['object'] = $object_url; $item['object'] = $object_url;
$item['receiver'] = []; $item['receiver'] = [];
$item['type'] = $activity['type']; $item['type'] = $activity['type'];
@ -659,7 +673,7 @@ class ActivityPub
} }
if (!empty($activity['instrument'])) { if (!empty($activity['instrument'])) {
$item['service'] = self::processElement($activity, 'instrument', 'name', 'Service'); $item['service'] = self::processElement($activity, 'instrument', 'name', 'type', 'Service');
} }
return $item; return $item;
} }
@ -670,19 +684,28 @@ class ActivityPub
if (empty($data)) { if (empty($data)) {
$data = $object; $data = $object;
if (empty($data)) { if (empty($data)) {
logger('Empty content'); logger('Empty content', LOGGER_DEBUG);
return false; return false;
} elseif (is_string($data)) {
logger('No object array provided.', LOGGER_DEBUG);
$item = Item::selectFirst([], ['uri' => $data]);
if (!DBA::isResult($item)) {
logger('Object with url ' . $data . ' was not found locally.', LOGGER_DEBUG);
return false;
}
logger('Using already stored item', LOGGER_DEBUG);
$data = self::createNote($item);
} else { } else {
logger('Using provided object'); logger('Using provided object', LOGGER_DEBUG);
} }
} }
if (empty($data['type'])) { if (empty($data['type'])) {
logger('Empty type'); logger('Empty type', LOGGER_DEBUG);
return false; return false;
} else { } else {
$type = $data['type']; $type = $data['type'];
logger('Type ' . $type); logger('Type ' . $type, LOGGER_DEBUG);
} }
if (in_array($type, ['Note', 'Article', 'Video'])) { if (in_array($type, ['Note', 'Article', 'Video'])) {
@ -745,10 +768,11 @@ class ActivityPub
$item['name'] = defaults($object, 'name', $item['name']); $item['name'] = defaults($object, 'name', $item['name']);
$item['summary'] = defaults($object, 'summary', null); $item['summary'] = defaults($object, 'summary', null);
$item['content'] = defaults($object, 'content', null); $item['content'] = defaults($object, 'content', null);
$item['location'] = self::processElement($object, 'location', 'name', 'Place'); $item['source'] = defaults($object, 'source', null);
$item['location'] = self::processElement($object, 'location', 'name', 'type', 'Place');
$item['attachments'] = defaults($object, 'attachment', null); $item['attachments'] = defaults($object, 'attachment', null);
$item['tags'] = defaults($object, 'tag', null); $item['tags'] = defaults($object, 'tag', null);
$item['service'] = self::processElement($object, 'instrument', 'name', 'Service'); $item['service'] = self::processElement($object, 'instrument', 'name', 'type', 'Service');
$item['alternate-url'] = self::processElement($object, 'url', 'href'); $item['alternate-url'] = self::processElement($object, 'url', 'href');
$item['receiver'] = self::getReceivers($object); $item['receiver'] = self::getReceivers($object);
@ -828,7 +852,7 @@ class ActivityPub
return $item; return $item;
} }
private static function processElement($array, $element, $key, $type = null) private static function processElement($array, $element, $key, $type = null, $type_value = null)
{ {
if (empty($array)) { if (empty($array)) {
return false; return false;
@ -842,7 +866,7 @@ class ActivityPub
return $array[$element]; return $array[$element];
} }
if (is_null($type)) { if (is_null($type_value)) {
if (!empty($array[$element][$key])) { if (!empty($array[$element][$key])) {
return $array[$element][$key]; return $array[$element][$key];
} }
@ -854,7 +878,7 @@ class ActivityPub
return false; return false;
} }
if (!empty($array[$element][$key]) && !empty($array[$element]['type']) && ($array[$element]['type'] == $type)) { if (!empty($array[$element][$key]) && !empty($array[$element][$type]) && ($array[$element][$type] == $type_value)) {
return $array[$element][$key]; return $array[$element][$key];
} }
@ -945,6 +969,11 @@ class ActivityPub
$item = self::constructAttachList($activity['attachments'], $item); $item = self::constructAttachList($activity['attachments'], $item);
$source = self::processElement($activity, 'source', 'content', 'mediaType', 'text/bbcode');
if (!empty($source)) {
$item['body'] = $source;
}
$item['protocol'] = Conversation::PARCEL_ACTIVITYPUB; $item['protocol'] = Conversation::PARCEL_ACTIVITYPUB;
$item['source'] = $body; $item['source'] = $body;
$item['conversation-uri'] = $activity['conversation']; $item['conversation-uri'] = $activity['conversation'];
@ -974,7 +1003,7 @@ class ActivityPub
Item::performLike($item['id'], strtolower($data['type'])); Item::performLike($item['id'], strtolower($data['type']));
} }
DBA::close($item); DBA::close($item);
logger('Activity done'); logger('Activity done', LOGGER_DEBUG);
} }
} }