Merge pull request #11948 from annando/transmit-quote
Support for transmitting quoted posts
This commit is contained in:
commit
844ed720b2
2 changed files with 70 additions and 40 deletions
|
@ -72,6 +72,8 @@ class ActivityPub
|
||||||
'schema' => 'http://schema.org#',
|
'schema' => 'http://schema.org#',
|
||||||
'manuallyApprovesFollowers' => 'as:manuallyApprovesFollowers',
|
'manuallyApprovesFollowers' => 'as:manuallyApprovesFollowers',
|
||||||
'sensitive' => 'as:sensitive', 'Hashtag' => 'as:Hashtag',
|
'sensitive' => 'as:sensitive', 'Hashtag' => 'as:Hashtag',
|
||||||
|
'quoteUrl' => 'as:quoteUrl',
|
||||||
|
'conversation' => 'ostatus:conversation',
|
||||||
'directMessage' => 'litepub:directMessage',
|
'directMessage' => 'litepub:directMessage',
|
||||||
'discoverable' => 'toot:discoverable',
|
'discoverable' => 'toot:discoverable',
|
||||||
'PropertyValue' => 'schema:PropertyValue',
|
'PropertyValue' => 'schema:PropertyValue',
|
||||||
|
|
|
@ -1356,10 +1356,11 @@ class Transmitter
|
||||||
* Returns a tag array for a given item array
|
* Returns a tag array for a given item array
|
||||||
*
|
*
|
||||||
* @param array $item Item array
|
* @param array $item Item array
|
||||||
|
* @param string $quote_url Url of the attached quote link
|
||||||
* @return array of tags
|
* @return array of tags
|
||||||
* @throws \Friendica\Network\HTTPException\InternalServerErrorException
|
* @throws \Friendica\Network\HTTPException\InternalServerErrorException
|
||||||
*/
|
*/
|
||||||
private static function createTagList(array $item): array
|
private static function createTagList(array $item, string $quote_url): array
|
||||||
{
|
{
|
||||||
$tags = [];
|
$tags = [];
|
||||||
|
|
||||||
|
@ -1389,6 +1390,17 @@ class Transmitter
|
||||||
$tags[] = ['type' => 'Mention', 'href' => $announce['actor']['url'], 'name' => '@' . $announce['actor']['addr']];
|
$tags[] = ['type' => 'Mention', 'href' => $announce['actor']['url'], 'name' => '@' . $announce['actor']['addr']];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// @see https://codeberg.org/fediverse/fep/src/branch/main/feps/fep-e232.md
|
||||||
|
if (!empty($quote_url)) {
|
||||||
|
// Currently deactivated because of compatibility issues with Pleroma
|
||||||
|
//$tags[] = [
|
||||||
|
// 'type' => 'Link',
|
||||||
|
// 'mediaType' => 'application/ld+json; profile="https://www.w3.org/ns/activitystreams"',
|
||||||
|
// 'href' => $quote_url,
|
||||||
|
// 'name' => '♲ ' . BBCode::convertForUriId($item['uri-id'], $quote_url, BBCode::ACTIVITYPUB)
|
||||||
|
//];
|
||||||
|
}
|
||||||
|
|
||||||
return $tags;
|
return $tags;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1396,27 +1408,16 @@ class Transmitter
|
||||||
* Adds attachment data to the JSON document
|
* Adds attachment data to the JSON document
|
||||||
*
|
*
|
||||||
* @param array $item Data of the item that is to be posted
|
* @param array $item Data of the item that is to be posted
|
||||||
* @param string $type Object type
|
|
||||||
*
|
*
|
||||||
* @return array with attachment data
|
* @return array with attachment data
|
||||||
* @throws \Friendica\Network\HTTPException\InternalServerErrorException
|
* @throws \Friendica\Network\HTTPException\InternalServerErrorException
|
||||||
*/
|
*/
|
||||||
private static function createAttachmentList(array $item, string $type): array
|
private static function createAttachmentList(array $item): array
|
||||||
{
|
{
|
||||||
$attachments = [];
|
$attachments = [];
|
||||||
|
|
||||||
$uriids = [$item['uri-id']];
|
|
||||||
$shared = BBCode::fetchShareAttributes($item['body']);
|
|
||||||
if (!empty($shared['guid'])) {
|
|
||||||
$shared_item = Post::selectFirst(['uri-id'], ['guid' => $shared['guid']]);
|
|
||||||
if (!empty($shared_item['uri-id'])) {
|
|
||||||
$uriids[] = $shared_item['uri-id'];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
$urls = [];
|
$urls = [];
|
||||||
foreach ($uriids as $uriid) {
|
foreach (Post\Media::getByURIId($item['uri-id'], [Post\Media::AUDIO, Post\Media::IMAGE, Post\Media::VIDEO, Post\Media::DOCUMENT, Post\Media::TORRENT]) as $attachment) {
|
||||||
foreach (Post\Media::getByURIId($uriid, [Post\Media::AUDIO, Post\Media::IMAGE, Post\Media::VIDEO, Post\Media::DOCUMENT, Post\Media::TORRENT]) as $attachment) {
|
|
||||||
if (in_array($attachment['url'], $urls)) {
|
if (in_array($attachment['url'], $urls)) {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
@ -1441,7 +1442,6 @@ class Transmitter
|
||||||
|
|
||||||
$attachments[] = $attach;
|
$attachments[] = $attach;
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
return $attachments;
|
return $attachments;
|
||||||
}
|
}
|
||||||
|
@ -1662,6 +1662,12 @@ class Transmitter
|
||||||
|
|
||||||
$body = BBCode::setMentionsToNicknames($body);
|
$body = BBCode::setMentionsToNicknames($body);
|
||||||
|
|
||||||
|
$shared = BBCode::fetchShareAttributes($body);
|
||||||
|
if (!empty($shared['link']) && !empty($shared['guid']) && !empty($shared['comment'])) {
|
||||||
|
$body = self::replaceSharedData($body);
|
||||||
|
$data['quoteUrl'] = $shared['link'];
|
||||||
|
}
|
||||||
|
|
||||||
$data['content'] = BBCode::convertForUriId($item['uri-id'], $body, BBCode::ACTIVITYPUB);
|
$data['content'] = BBCode::convertForUriId($item['uri-id'], $body, BBCode::ACTIVITYPUB);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1671,6 +1677,12 @@ class Transmitter
|
||||||
$language = self::getLanguage($item);
|
$language = self::getLanguage($item);
|
||||||
if (!empty($language)) {
|
if (!empty($language)) {
|
||||||
$richbody = BBCode::setMentionsToNicknames($item['body'] ?? '');
|
$richbody = BBCode::setMentionsToNicknames($item['body'] ?? '');
|
||||||
|
|
||||||
|
$shared = BBCode::fetchShareAttributes($richbody);
|
||||||
|
if (!empty($shared['link']) && !empty($shared['guid']) && !empty($shared['comment'])) {
|
||||||
|
$richbody = self::replaceSharedData($richbody);
|
||||||
|
}
|
||||||
|
|
||||||
$richbody = BBCode::removeAttachment($richbody);
|
$richbody = BBCode::removeAttachment($richbody);
|
||||||
|
|
||||||
$data['contentMap'][$language] = BBCode::convertForUriId($item['uri-id'], $richbody, BBCode::EXTERNAL);
|
$data['contentMap'][$language] = BBCode::convertForUriId($item['uri-id'], $richbody, BBCode::EXTERNAL);
|
||||||
|
@ -1682,8 +1694,8 @@ class Transmitter
|
||||||
$data['diaspora:comment'] = $item['signed_text'];
|
$data['diaspora:comment'] = $item['signed_text'];
|
||||||
}
|
}
|
||||||
|
|
||||||
$data['attachment'] = self::createAttachmentList($item, $type);
|
$data['attachment'] = self::createAttachmentList($item);
|
||||||
$data['tag'] = self::createTagList($item);
|
$data['tag'] = self::createTagList($item, $data['quoteUrl'] ?? '');
|
||||||
|
|
||||||
if (empty($data['location']) && (!empty($item['coord']) || !empty($item['location']))) {
|
if (empty($data['location']) && (!empty($item['coord']) || !empty($item['location']))) {
|
||||||
$data['location'] = self::createLocation($item);
|
$data['location'] = self::createLocation($item);
|
||||||
|
@ -1698,6 +1710,22 @@ class Transmitter
|
||||||
return $data;
|
return $data;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Replace the share block with a link
|
||||||
|
*
|
||||||
|
* @param string $body
|
||||||
|
* @return string
|
||||||
|
*/
|
||||||
|
private static function replaceSharedData(string $body): string
|
||||||
|
{
|
||||||
|
return BBCode::convertShare(
|
||||||
|
$body,
|
||||||
|
function (array $attributes) {
|
||||||
|
return '♲ ' . $attributes['link'];
|
||||||
|
}
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Fetches the language from the post, the user or the system.
|
* Fetches the language from the post, the user or the system.
|
||||||
*
|
*
|
||||||
|
|
Loading…
Reference in a new issue