mirror of
https://github.com/friendica/friendica
synced 2025-01-12 06:04:42 +00:00
Public posts to Pleroma do work now, limited posts to Hubzilla and Mastodon as well
This commit is contained in:
parent
f772ece86f
commit
464650d4d7
1 changed files with 65 additions and 9 deletions
|
@ -174,6 +174,7 @@ class ActivityPub
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
|
$data['to'][] = System::baseUrl() . '/followers/' . $item['author-nick'];
|
||||||
$receiver_list = Item::enumeratePermissions($item);
|
$receiver_list = Item::enumeratePermissions($item);
|
||||||
|
|
||||||
$mentioned = [];
|
$mentioned = [];
|
||||||
|
@ -209,7 +210,8 @@ class ActivityPub
|
||||||
|
|
||||||
$terms = Term::tagArrayFromItemId($item['id']);
|
$terms = Term::tagArrayFromItemId($item['id']);
|
||||||
if (!$item['private']) {
|
if (!$item['private']) {
|
||||||
$contacts = DBA::select('contact', ['notify', 'batch'], ['uid' => $item['uid'], 'network' => Protocol::ACTIVITYPUB]);
|
$contacts = DBA::select('contact', ['notify', 'batch'], ['uid' => $item['uid'],
|
||||||
|
'rel' => [Contact::FOLLOWER, Contact::FRIEND], 'network' => Protocol::ACTIVITYPUB]);
|
||||||
while ($contact = DBA::fetch($contacts)) {
|
while ($contact = DBA::fetch($contacts)) {
|
||||||
$contact = defaults($contact, 'batch', $contact['notify']);
|
$contact = defaults($contact, 'batch', $contact['notify']);
|
||||||
$inboxes[$contact] = $contact;
|
$inboxes[$contact] = $contact;
|
||||||
|
@ -240,7 +242,8 @@ class ActivityPub
|
||||||
$contact = DBA::selectFirst('contact', ['url'], ['id' => $cid, 'network' => Protocol::ACTIVITYPUB]);
|
$contact = DBA::selectFirst('contact', ['url'], ['id' => $cid, 'network' => Protocol::ACTIVITYPUB]);
|
||||||
$profile = Probe::uri($contact['url'], Protocol::ACTIVITYPUB);
|
$profile = Probe::uri($contact['url'], Protocol::ACTIVITYPUB);
|
||||||
if ($profile['network'] == Protocol::ACTIVITYPUB) {
|
if ($profile['network'] == Protocol::ACTIVITYPUB) {
|
||||||
$target = defaults($profile, 'batch', $profile['notify']);
|
//$target = defaults($profile, 'batch', $profile['notify']);
|
||||||
|
$target = $profile['notify'];
|
||||||
$inboxes[$target] = $target;
|
$inboxes[$target] = $target;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -250,12 +253,22 @@ class ActivityPub
|
||||||
$contact = DBA::selectFirst('contact', ['url'], ['id' => $receiver, 'network' => Protocol::ACTIVITYPUB]);
|
$contact = DBA::selectFirst('contact', ['url'], ['id' => $receiver, 'network' => Protocol::ACTIVITYPUB]);
|
||||||
$profile = Probe::uri($contact['url'], Protocol::ACTIVITYPUB);
|
$profile = Probe::uri($contact['url'], Protocol::ACTIVITYPUB);
|
||||||
if ($profile['network'] == Protocol::ACTIVITYPUB) {
|
if ($profile['network'] == Protocol::ACTIVITYPUB) {
|
||||||
$target = defaults($profile, 'batch', $profile['notify']);
|
//$target = defaults($profile, 'batch', $profile['notify']);
|
||||||
|
$target = $profile['notify'];
|
||||||
$inboxes[$target] = $target;
|
$inboxes[$target] = $target;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
$profile = Probe::uri($target, Protocol::ACTIVITYPUB);
|
||||||
|
if (!empty($profile['batch'])) {
|
||||||
|
unset($inboxes[$profile['batch']]);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!empty($profile['notify'])) {
|
||||||
|
unset($inboxes[$profile['notify']]);
|
||||||
|
}
|
||||||
|
|
||||||
return $inboxes;
|
return $inboxes;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -285,6 +298,13 @@ class ActivityPub
|
||||||
$data['type'] = 'Create';
|
$data['type'] = 'Create';
|
||||||
$data['id'] = $item['uri'] . '#activity';
|
$data['id'] = $item['uri'] . '#activity';
|
||||||
$data['actor'] = $item['author-link'];
|
$data['actor'] = $item['author-link'];
|
||||||
|
|
||||||
|
$data['published'] = DateTimeFormat::utc($item["created"]."+00:00", DateTimeFormat::ATOM);
|
||||||
|
|
||||||
|
if ($item["created"] != $item["edited"]) {
|
||||||
|
$data['updated'] = DateTimeFormat::utc($item["edited"]."+00:00", DateTimeFormat::ATOM);
|
||||||
|
}
|
||||||
|
|
||||||
$data = array_merge($data, ActivityPub::createPermissionBlockForItem($item));
|
$data = array_merge($data, ActivityPub::createPermissionBlockForItem($item));
|
||||||
|
|
||||||
$data['object'] = self::createNote($item);
|
$data['object'] = self::createNote($item);
|
||||||
|
@ -311,6 +331,38 @@ class ActivityPub
|
||||||
return $data;
|
return $data;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private static function createTagList($item)
|
||||||
|
{
|
||||||
|
$tags = [];
|
||||||
|
|
||||||
|
$receiver_list = Item::enumeratePermissions($item);
|
||||||
|
foreach ($receiver_list as $receiver) {
|
||||||
|
$contact = DBA::selectFirst('contact', ['url', 'addr'], ['id' => $receiver, 'network' => Protocol::ACTIVITYPUB]);
|
||||||
|
if (!empty($contact['addr'])) {
|
||||||
|
$mention = '@' . $contact['addr'];
|
||||||
|
} else {
|
||||||
|
$mention = '@' . $term['url'];
|
||||||
|
}
|
||||||
|
$tags[] = ['type' => 'Mention', 'href' => $contact['url'], 'name' => $mention];
|
||||||
|
}
|
||||||
|
|
||||||
|
$terms = Term::tagArrayFromItemId($item['id']);
|
||||||
|
foreach ($terms as $term) {
|
||||||
|
if ($term['type'] == TERM_MENTION) {
|
||||||
|
$contact = Contact::getDetailsByURL($term['url']);
|
||||||
|
if (!empty($contact['addr'])) {
|
||||||
|
$mention = '@' . $contact['addr'];
|
||||||
|
} else {
|
||||||
|
$mention = '@' . $term['url'];
|
||||||
|
}
|
||||||
|
|
||||||
|
$tags[] = ['type' => 'Mention', 'href' => $term['url'], 'name' => $mention];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return $tags;
|
||||||
|
}
|
||||||
|
|
||||||
public static function createNote($item)
|
public static function createNote($item)
|
||||||
{
|
{
|
||||||
$data = [];
|
$data = [];
|
||||||
|
@ -332,16 +384,20 @@ class ActivityPub
|
||||||
$data['actor'] = $item['author-link'];
|
$data['actor'] = $item['author-link'];
|
||||||
$data = array_merge($data, ActivityPub::createPermissionBlockForItem($item));
|
$data = array_merge($data, ActivityPub::createPermissionBlockForItem($item));
|
||||||
$data['published'] = DateTimeFormat::utc($item["created"]."+00:00", DateTimeFormat::ATOM);
|
$data['published'] = DateTimeFormat::utc($item["created"]."+00:00", DateTimeFormat::ATOM);
|
||||||
|
|
||||||
|
if ($item["created"] != $item["edited"]) {
|
||||||
$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['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
|
||||||
//$data['tag'] = []; /// @ToDo
|
$data['tag'] = self::createTagList($item);
|
||||||
//$data['attachment'] = []; // @ToDo
|
$data['attachment'] = []; // @ToDo
|
||||||
return $data;
|
return $data;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue