]> git.mxchange.org Git - friendica.git/blobdiff - src/Content/ContactSelector.php
Replace abstract content with a space to prevent missing spaces
[friendica.git] / src / Content / ContactSelector.php
index 38227bc6e23a6dfb3ab9f17592a5446427fc547e..9035d37e73c01d3c838e35c30bbc662e1507acc0 100644 (file)
@@ -1,7 +1,24 @@
 <?php
 /**
- * @file src/Content/ContactSelector.php
+ * @copyright Copyright (C) 2010-2022, the Friendica project
+ *
+ * @license GNU AGPL version 3 or any later version
+ *
+ * This program is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU Affero General Public License as
+ * published by the Free Software Foundation, either version 3 of the
+ * License, or (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+ * GNU Affero General Public License for more details.
+ *
+ * You should have received a copy of the GNU Affero General Public License
+ * along with this program.  If not, see <https://www.gnu.org/licenses/>.
+ *
  */
+
 namespace Friendica\Content;
 
 use Friendica\Core\Hook;
@@ -16,6 +33,9 @@ use Friendica\Util\Strings;
  */
 class ContactSelector
 {
+       static $serverdata = [];
+       static $server_url = [];
+
        /**
         * @param string  $current  current
         * @param boolean $disabled optional, default false
@@ -44,6 +64,21 @@ class ContactSelector
                return $o;
        }
 
+       private static function getServerForProfile(string $profile)
+       {
+               $server_url = self::getServerURLForProfile($profile);
+
+               if (!empty(self::$serverdata[$server_url])) {
+                       return self::$serverdata[$server_url];
+               }
+
+               // Now query the GServer for the platform name
+               $gserver = DBA::selectFirst('gserver', ['platform', 'network'], ['nurl' => $server_url]);
+
+               self::$serverdata[$server_url] = $gserver;
+               return $gserver;
+       }
+
        /**
         * @param string $profile Profile URL
         * @return string Server URL
@@ -51,6 +86,10 @@ class ContactSelector
         */
        private static function getServerURLForProfile($profile)
        {
+               if (!empty(self::$server_url[$profile])) {
+                       return self::$server_url[$profile];
+               }
+
                $server_url = '';
 
                // Fetch the server url from the contact table
@@ -59,14 +98,6 @@ class ContactSelector
                        $server_url = Strings::normaliseLink($contact['baseurl']);
                }
 
-               if (empty($server_url)) {
-                       // Fetch the server url from the gcontact table
-                       $gcontact = DBA::selectFirst('gcontact', ['server_url'], ['nurl' => Strings::normaliseLink($profile)]);
-                       if (!empty($gcontact) && !empty($gcontact['server_url'])) {
-                               $server_url = Strings::normaliseLink($gcontact['server_url']);
-                       }
-               }
-
                if (empty($server_url)) {
                        // Create the server url out of the profile url
                        $parts = parse_url($profile);
@@ -74,6 +105,8 @@ class ContactSelector
                        $server_url = Strings::normaliseLink(Network::unparseURL($parts));
                }
 
+               self::$server_url[$profile] = $server_url;
+
                return $server_url;
        }
 
@@ -84,7 +117,7 @@ class ContactSelector
         * @return string
         * @throws \Friendica\Network\HTTPException\InternalServerErrorException
         */
-       public static function networkToName($network, $profile = '', $protocol = '')
+       public static function networkToName($network, $profile = '', $protocol = '', $gsid = 0)
        {
                $nets = [
                        Protocol::DFRN      =>   DI::l10n()->t('DFRN'),
@@ -114,24 +147,26 @@ class ContactSelector
                $networkname = str_replace($search, $replace, $network);
 
                if ((in_array($network, Protocol::FEDERATED)) && ($profile != "")) {
-                       $server_url = self::getServerURLForProfile($profile);
-
-                       // Now query the GServer for the platform name
-                       $gserver = DBA::selectFirst('gserver', ['platform', 'network'], ['nurl' => $server_url]);
+                       if (!empty($gsid) && !empty(self::$serverdata[$gsid])) {
+                               $gserver = self::$serverdata[$gsid];
+                       } elseif (!empty($gsid)) {
+                               $gserver = DBA::selectFirst('gserver', ['platform', 'network'], ['id' => $gsid]);
+                               self::$serverdata[$gsid] = $gserver;
+                       } else {
+                               $gserver = self::getServerForProfile($profile);
+                       }
 
-                       if (DBA::isResult($gserver)) {
-                               if (!empty($gserver['platform'])) {
-                                       $platform = $gserver['platform'];
-                               } elseif (!empty($gserver['network']) && ($gserver['network'] != Protocol::ACTIVITYPUB)) {
-                                       $platform = self::networkToName($gserver['network']);
-                               }
+                       if (!empty($gserver['platform'])) {
+                               $platform = $gserver['platform'];
+                       } elseif (!empty($gserver['network']) && ($gserver['network'] != Protocol::ACTIVITYPUB)) {
+                               $platform = self::networkToName($gserver['network']);
+                       }
 
-                               if (!empty($platform)) {
-                                       $networkname = $platform;
+                       if (!empty($platform)) {
+                               $networkname = $platform;
 
-                                       if ($network == Protocol::ACTIVITYPUB) {
-                                               $networkname .= ' (AP)';
-                                       }
+                               if ($network == Protocol::ACTIVITYPUB) {
+                                       $networkname .= ' (AP)';
                                }
                        }
                }
@@ -183,12 +218,8 @@ class ContactSelector
                $network_icon = str_replace($search, $replace, $network);
 
                if ((in_array($network, Protocol::FEDERATED)) && ($profile != "")) {
-                       $server_url = self::getServerURLForProfile($profile);
-
-                       // Now query the GServer for the platform name
-                       $gserver = DBA::selectFirst('gserver', ['platform'], ['nurl' => $server_url]);
-
-                       if (DBA::isResult($gserver) && !empty($gserver['platform'])) {
+                       $gserver = self::getServerForProfile($profile);
+                       if (!empty($gserver['platform'])) {
                                $network_icon = $platform_icons[strtolower($gserver['platform'])] ?? $network_icon;
                        }
                }