]> git.mxchange.org Git - friendica.git/commitdiff
Issue 12373: Fix communication to Diaspora
authorMichael <heluecht@pirati.ca>
Sat, 10 Dec 2022 12:08:55 +0000 (12:08 +0000)
committerMichael <heluecht@pirati.ca>
Sat, 10 Dec 2022 12:08:55 +0000 (12:08 +0000)
src/Model/Contact.php
src/Network/Probe.php
src/Protocol/Diaspora.php
src/Worker/Delivery.php
src/Worker/Notifier.php

index e80f0752ea6b4dda10f995041287aaa152438b49..873de08906f26d00d90c638f6e3950917b600295 100644 (file)
@@ -1396,6 +1396,8 @@ class Contact
 
                if ($data['network'] == Protocol::DIASPORA) {
                        DI::dsprContact()->updateFromProbeArray($data);
+               } elseif (!empty($data['networks'][Protocol::DIASPORA])) {
+                       DI::dsprContact()->updateFromProbeArray($data['networks'][Protocol::DIASPORA]);
                }
 
                self::updateFromProbeArray($contact_id, $data);
@@ -2487,6 +2489,8 @@ class Contact
 
                if ($ret['network'] == Protocol::DIASPORA) {
                        DI::dsprContact()->updateFromProbeArray($ret);
+               } elseif (!empty($ret['networks'][Protocol::DIASPORA])) {
+                       DI::dsprContact()->updateFromProbeArray($ret['networks'][Protocol::DIASPORA]);
                }
 
                return self::updateFromProbeArray($id, $ret);
index d79cd4055f8dcf493519cb4bcb8882d5ff927f0d..9cdcd5fa8956b767372aeb79ae3e289621447fc8 100644 (file)
@@ -134,6 +134,13 @@ class Probe
                        }
                }
 
+               $newdata['networks'] = $data['networks'] ?? [];
+               foreach ([Protocol::DIASPORA, Protocol::OSTATUS] as $network) {
+                       if (empty($newdata['networks'][$network])) {
+                               unset($newdata['networks'][$network]);
+                       }
+               }
+
                // We don't use the "priority" field anymore and replace it with a dummy.
                $newdata['priority'] = 0;
 
@@ -345,7 +352,11 @@ class Probe
                                $data = [];
                        }
                        if (empty($data) || (!empty($ap_profile) && empty($network) && (($data['network'] ?? '') != Protocol::DFRN))) {
+                               $networks = $data['networks'] ?? [];
+                               unset($data['networks']);
+                               $networks[$data['network']] = $data;
                                $data = $ap_profile;
+                               $data['networks'] = $networks;
                        } elseif (!empty($ap_profile)) {
                                $ap_profile['batch'] = '';
                                $data = array_merge($ap_profile, $data);
@@ -716,9 +727,13 @@ class Probe
                }
                if ((!$result && ($network == '')) || ($network == Protocol::DIASPORA)) {
                        $result = self::diaspora($webfinger);
+               } else {
+                       $result['networks'][Protocol::DIASPORA] = self::diaspora($webfinger);
                }
                if ((!$result && ($network == '')) || ($network == Protocol::OSTATUS)) {
                        $result = self::ostatus($webfinger);
+               } else {
+                       $result['networks'][Protocol::OSTATUS] = self::ostatus($webfinger);
                }
                if (in_array($network, ['', Protocol::ZOT])) {
                        $result = self::zot($webfinger, $result, $baseurl);
index 3c60f4041ba98ae374dbcce1f5021bf6c5064e7b..e5194ba3d0d4d3c23acb6812ccb8b2a02337c0be 100644 (file)
@@ -826,9 +826,15 @@ class Diaspora
         */
        public static function isSupportedByContactUrl(string $url, ?bool $update = null): bool
        {
-               $contact = Contact::getByURL($url, $update);
+               $contact = Contact::getByURL($url, $update, ['uri-id', 'network']);
 
-               return DI::dsprContact()->existsByUriId($contact['uri-id'] ?? 0);
+               $supported = DI::dsprContact()->existsByUriId($contact['uri-id'] ?? 0);
+
+               if (!$supported && is_null($update) && ($contact['network'] == Protocol::DFRN)) {
+                       $supported = self::isSupportedByContactUrl($url, true);
+               }
+
+               return $supported;
        }
 
        /**
@@ -4035,6 +4041,7 @@ class Diaspora
 
                if (!self::parentSupportDiaspora($item['thr-parent-id'])) {
                        Logger::info('One of the parents does not support Diaspora. A signature will not be created.', ['uri-id' => $item['uri-id'], 'guid' => $item['guid']]);
+                       echo "5";
                        return false;
                }
 
@@ -4064,7 +4071,7 @@ class Diaspora
                        return false;
                }
 
-               if (!self::isSupportedByContactUrl($parent_post['author-link'], false)) {
+               if (!self::isSupportedByContactUrl($parent_post['author-link'])) {
                        Logger::info('Parent author is no Diaspora contact.', ['parent-id' => $parent_id]);
                        return false;
                }
index cec894480ca90cee1f4c8b3f08bd5eb2a2c37db6..1a0758987aa98554f95f9e0e35979809f93c8a4f 100644 (file)
@@ -277,7 +277,7 @@ class Delivery
        private static function deliverDFRN(string $cmd, array $contact, array $owner, array $items, array $target_item, bool $public_message, bool $top_level, bool $followup, int $server_protocol = null)
        {
                // Transmit Diaspora reshares via Diaspora if the Friendica contact support Diaspora
-               if (Diaspora::getReshareDetails($target_item ?? []) && Diaspora::isSupportedByContactUrl($contact['addr'], false)) {
+               if (Diaspora::getReshareDetails($target_item ?? []) && Diaspora::isSupportedByContactUrl($contact['addr'])) {
                        Logger::info('Reshare will be transmitted via Diaspora', ['url' => $contact['url'], 'guid' => ($target_item['guid'] ?? '') ?: $target_item['id']]);
                        self::deliverDiaspora($cmd, $contact, $owner, $items, $target_item, $public_message, $top_level, $followup);
                        return;
index db593b6a4748fdf9b1fa5a0eaa3cf97de7645a2e..c09faca89b27c033fce18894a934b94a6e22af89 100644 (file)
@@ -191,7 +191,7 @@ class Notifier
                        // when the original comment author does support the Diaspora protocol.
                        if ($thr_parent['author-link'] && $target_item['parent-uri'] != $target_item['thr-parent']) {
                                $diaspora_delivery = Diaspora::isSupportedByContactUrl($thr_parent['author-link']);
-                               if ($diaspora_delivery &&  empty($target_item['signed_text'])) {
+                               if ($diaspora_delivery && empty($target_item['signed_text'])) {
                                        Logger::debug('Post has got no Diaspora signature, so there will be no Diaspora delivery', ['guid' => $target_item['guid'], 'uri-id' => $target_item['uri-id']]);
                                        $diaspora_delivery = false;
                                }