Use the follower collection

This commit is contained in:
Michael 2018-09-22 04:49:16 +00:00
parent b7744ae3eb
commit 71cbe56293

View file

@ -216,7 +216,7 @@ class ActivityPub
return $data; return $data;
} }
private static function fetchTargetInboxesFromConversation($item) private static function fetchTargetInboxesFromConversation($item, $uid)
{ {
if (empty($item['thr-parent'])) { if (empty($item['thr-parent'])) {
return []; return [];
@ -244,6 +244,15 @@ class ActivityPub
$activity[$element] = [$activity[$element]]; $activity[$element] = [$activity[$element]];
} }
foreach ($activity[$element] as $receiver) { foreach ($activity[$element] as $receiver) {
if ($receiver == $profile['followers']) {
$contacts = DBA::select('contact', ['notify', 'batch'], ['uid' => $uid,
'rel' => [Contact::FOLLOWER, Contact::FRIEND], 'network' => Protocol::ACTIVITYPUB]);
while ($contact = DBA::fetch($contacts)) {
$contact = defaults($contact, 'batch', $contact['notify']);
$inboxes[$contact] = $contact;
}
DBA::close($contacts);
} else {
$profile = self::fetchprofile($receiver); $profile = self::fetchprofile($receiver);
if (!empty($profile)) { if (!empty($profile)) {
$target = defaults($profile, 'sharedinbox', $profile['inbox']); $target = defaults($profile, 'sharedinbox', $profile['inbox']);
@ -251,12 +260,13 @@ class ActivityPub
} }
} }
} }
}
return $inboxes; return $inboxes;
} }
public static function fetchTargetInboxes($item, $uid) public static function fetchTargetInboxes($item, $uid)
{ {
$inboxes = self::fetchTargetInboxesFromConversation($item); $inboxes = self::fetchTargetInboxesFromConversation($item, $uid);
$parents = Item::select(['author-link', 'owner-link'], ['parent' => $item['parent']]); $parents = Item::select(['author-link', 'owner-link'], ['parent' => $item['parent']]);
while ($parent = Item::fetch($parents)) { while ($parent = Item::fetch($parents)) {