}
}
// @todo Judge between the links to use the one with most information
- if (!$found && (empty($attachment) || empty($attachment['name']) || empty($attachment['description']))) {
+ if (!$found && (empty($attachment) || !empty($link['author-name']) ||
+ (empty($attachment['name']) && !empty($link['name'])) ||
+ (empty($attachment['description']) && !empty($link['description'])) ||
+ (empty($attachment['preview']) && !empty($link['preview'])))) {
$attachment = $link;
}
}
return true;
}
+
+ /**
+ * Improve the data in shared posts
+ *
+ * @param array $item
+ * @return string body
+ */
+ public static function improveSharedDataInBody(array $item)
+ {
+ $shared = BBCode::fetchShareAttributes($item['body']);
+ if (!empty($shared['link'])) {
+ $id = self::fetchByLink($shared['link']);
+ Logger::info('Fetched shared post', ['uri-id' => $item['uri-id'], 'id' => $id, 'author' => $shared['profile'], 'url' => $shared['link'], 'guid' => $shared['guid'], 'callstack' => System::callstack()]);
+ if ($id) {
+ $shared_item = Post::selectFirst(['author-name', 'author-link', 'author-avatar', 'plink', 'created', 'guid', 'title', 'body'], ['id' => $id]);
+ $shared_content = BBCode::getShareOpeningTag($shared_item['author-name'], $shared_item['author-link'], $shared_item['author-avatar'], $shared_item['plink'], $shared_item['created'], $shared_item['guid']);
+
+ if (!empty($shared_item['title'])) {
+ $shared_content .= '[h3]'.$shared_item['title'].'[/h3]'."\n";
+ }
+
+ $shared_content .= $shared_item['body'];
+
+ $item['body'] = preg_replace("/\[share.*?\](.*)\[\/share\]/ism", $shared_content . '[/share]', $item['body']);
+ Logger::info('New shared data', ['uri-id' => $item['uri-id'], 'id' => $id, 'shared_item' => $shared_item]);
+ }
+ }
+ return $item['body'];
+ }
}
namespace Friendica\Protocol\ActivityPub;
-use Friendica\Content\PageInfo;
use Friendica\Content\Text\BBCode;
use Friendica\Content\Text\HTML;
use Friendica\Content\Text\Markdown;
if (!empty($activity['source'])) {
$item['body'] = $activity['source'];
$item['raw-body'] = $content;
+ $item['body'] = Item::improveSharedDataInBody($item);
} else {
if (empty($activity['directmessage']) && ($item['thr-parent'] != $item['uri']) && ($item['gravity'] == GRAVITY_COMMENT)) {
$item_private = !in_array(0, $activity['item_receiver']);
$item['uri-id'] = ItemURI::insert(['uri' => $item['uri'], 'guid' => $item['guid']]);
+ $item["body"] = Item::improveSharedDataInBody($item);
+
Tag::storeFromBody($item['uri-id'], $item["body"]);
// We store the data from "dfrn:diaspora_signature" in a different table, this is done in "Item::insert"
return 403;
}
}
-
+
// Get the type of the item (Top level post, reply or remote reply)
$entrytype = self::getEntryType($importer, $item);