]> git.mxchange.org Git - friendica.git/blobdiff - src/Content/ContactSelector.php
Fix magic links in contact photo menu
[friendica.git] / src / Content / ContactSelector.php
index 38227bc6e23a6dfb3ab9f17592a5446427fc547e..d9f475e2e7595f1fa028ece7297177fb21e319e5 100644 (file)
@@ -1,7 +1,24 @@
 <?php
 /**
- * @file src/Content/ContactSelector.php
+ * @copyright Copyright (C) 2010-2023, 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,12 +33,15 @@ use Friendica\Util\Strings;
  */
 class ContactSelector
 {
+       static $serverdata = [];
+       static $server_url = [];
+
        /**
         * @param string  $current  current
         * @param boolean $disabled optional, default false
         * @return string
         */
-       public static function pollInterval($current, $disabled = false)
+       public static function pollInterval(string $current, bool $disabled = false): string
        {
                $dis = (($disabled) ? ' disabled="disabled" ' : '');
                $o = '';
@@ -44,13 +64,32 @@ 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
         * @throws \Exception
         */
-       private static function getServerURLForProfile($profile)
+       private static function getServerURLForProfile(string $profile): string
        {
+               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,17 +105,22 @@ class ContactSelector
                        $server_url = Strings::normaliseLink(Network::unparseURL($parts));
                }
 
+               self::$server_url[$profile] = $server_url;
+
                return $server_url;
        }
 
        /**
+        * Determines network name
+        *
         * @param string $network  network of the contact
         * @param string $profile  optional, default empty
         * @param string $protocol (Optional) Protocol that is used for the transmission
+        * @param int $gsid Server id
         * @return string
         * @throws \Friendica\Network\HTTPException\InternalServerErrorException
         */
-       public static function networkToName($network, $profile = '', $protocol = '')
+       public static function networkToName(string $network, string $profile = '', string $protocol = '', int $gsid = null): string
        {
                $nets = [
                        Protocol::DFRN      =>   DI::l10n()->t('DFRN'),
@@ -104,6 +140,7 @@ class ContactSelector
                        Protocol::STATUSNET =>   DI::l10n()->t('GNU Social Connector'),
                        Protocol::ACTIVITYPUB => DI::l10n()->t('ActivityPub'),
                        Protocol::PNUT      =>   DI::l10n()->t('pnut'),
+                       Protocol::TUMBLR    =>   DI::l10n()->t('Tumblr'),
                ];
 
                Hook::callAll('network_to_name', $nets);
@@ -114,24 +151,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)';
                                }
                        }
                }
@@ -144,12 +183,15 @@ class ContactSelector
        }
 
        /**
+        * Determines network's icon name
+        *
         * @param string $network network
         * @param string $profile optional, default empty
-        * @return string
+        * @param int $gsid Server id
+        * @return string Name for network icon
         * @throws \Exception
         */
-       public static function networkToIcon($network, $profile = "")
+       public static function networkToIcon(string $network, string $profile = "", int $gsid = null): string
        {
                $nets = [
                        Protocol::DFRN      =>   'friendica',
@@ -169,6 +211,7 @@ class ContactSelector
                        Protocol::STATUSNET =>   'gnu-social',
                        Protocol::ACTIVITYPUB => 'activitypub',
                        Protocol::PNUT      =>   'file-text-o', /// @todo
+                       Protocol::TUMBLR    =>   'tumblr',
                ];
 
                $platform_icons = ['diaspora' => 'diaspora', 'friendica' => 'friendica', 'friendika' => 'friendica',
@@ -183,12 +226,15 @@ 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'])) {
+                       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 (!empty($gserver['platform'])) {
                                $network_icon = $platform_icons[strtolower($gserver['platform'])] ?? $network_icon;
                        }
                }