From b8f81d5e7d92213559de023cae378bc0a55e7361 Mon Sep 17 00:00:00 2001 From: Michael Date: Sun, 8 Dec 2019 22:04:32 +0000 Subject: [PATCH] Relocate check for announce --- src/Worker/Delivery.php | 8 -------- src/Worker/Notifier.php | 5 +++++ 2 files changed, 5 insertions(+), 8 deletions(-) diff --git a/src/Worker/Delivery.php b/src/Worker/Delivery.php index 0d01d8284..da0c8f2ad 100644 --- a/src/Worker/Delivery.php +++ b/src/Worker/Delivery.php @@ -16,7 +16,6 @@ use Friendica\Protocol\DFRN; use Friendica\Protocol\Diaspora; use Friendica\Protocol\Email; use Friendica\Protocol\Activity; -use Friendica\Protocol\ActivityPub; use Friendica\Util\Strings; use Friendica\Util\Network; use Friendica\Core\Worker; @@ -252,13 +251,6 @@ class Delivery extends BaseObject */ private static function deliverDFRN($cmd, $contact, $owner, $items, $target_item, $public_message, $top_level, $followup) { - // Skip transmitting the announce via DFRN when it had already been done via AP - if (ActivityPub\Transmitter::isAnnounce($target_item) && !empty(Model\APContact::getByURL($contact['url'], false))) { - Logger::info('Announce had already been transmitted', ['url' => $contact['url'], 'guid' => ($target_item['guid'] ?? '') ?: $target_item['id']]); - Model\ItemDeliveryData::incrementQueueDone($target_item['id']); - return; - } - // Transmit Diaspora reshares via Diaspora if the Friendica contact support Diaspora if (Diaspora::isReshare($target_item['body']) && !empty(Diaspora::personByHandle(contact['addr'], false))) { Logger::info('Reshare will be transmitted via Diaspora', ['url' => $contact['url'], 'guid' => ($target_item['guid'] ?? '') ?: $target_item['id']]); diff --git a/src/Worker/Notifier.php b/src/Worker/Notifier.php index 3e4efb5f3..19bd51885 100644 --- a/src/Worker/Notifier.php +++ b/src/Worker/Notifier.php @@ -625,6 +625,11 @@ class Notifier return false; } + // We deliver reshares via AP whenever possible + if (ActivityPub\Transmitter::isAnnounce($item)) { + return true; + } + // Skip DFRN when the item will be (forcefully) delivered via AP if (Config::get('debug', 'total_ap_delivery') && ($contact['network'] == Protocol::DFRN) && !empty(APContact::getByURL($contact['url'], false))) { return true;