]> git.mxchange.org Git - friendica.git/commitdiff
Improved avatar handling (timestamps for caching)
authorMichael <heluecht@pirati.ca>
Tue, 29 Jun 2021 06:15:45 +0000 (06:15 +0000)
committerMichael <heluecht@pirati.ca>
Tue, 29 Jun 2021 06:15:45 +0000 (06:15 +0000)
src/Model/Contact.php
src/Model/Profile.php
src/Object/Api/Mastodon/Account.php

index 86f848da39d4008f17343aa12dee8c8620c27635..60213cacb51751f232c9b3067ef5b16b5317baa1 100644 (file)
@@ -1502,18 +1502,22 @@ class Contact
                if (!empty($contact)) {
                        $contact = self::checkAvatarCacheByArray($contact, $no_update);
                        if (!empty($contact[$field])) {
-                               $avatar = $contact[$field];
+                               return $contact[$field];
+                       } elseif (!empty($contact['id'])) {
+                               return self::getAvatarUrlForId($contact['id'], $size, $contact['updated'] ?? '');
+                       } elseif (!empty($contact['avatar'])) {
+                               $avatar = $contact['avatar'];
                        }
                }
 
-               if ($no_update && empty($avatar) && !empty($contact['avatar'])) {
-                       $avatar = $contact['avatar'];
+               if (empty($avatar)) {
+                       $avatar = self::getDefaultAvatar([], $size);
                }
 
-               if (!empty($avatar) && Proxy::isLocalImage($avatar)) {
+               if (Proxy::isLocalImage($avatar)) {
                        return $avatar;
                } else {
-                       return self::getAvatarUrlForId($contact['id'], $size);
+                       return Proxy::proxifyUrl($avatar, false, $size);
                }
        }
 
@@ -1661,12 +1665,20 @@ class Contact
        /**
         * Get avatar link for given contact id
         *
-        * @param integer $cid  contact id
-        * @param string  $size One of the ProxyUtils::SIZE_* constants
+        * @param integer $cid     contact id
+        * @param string  $size    One of the ProxyUtils::SIZE_* constants
+        * @param string  $updated Contact update date
         * @return string avatar link
         */
-       public static function getAvatarUrlForId(int $cid, string $size = ''):string
+       public static function getAvatarUrlForId(int $cid, string $size = '', string $updated = ''):string
        {
+               // We have to fetch the "updated" variable when it wasn't provided
+               // The parameter can be provided to improve performance
+               if (empty($updated)) {
+                       $contact = self::getById($cid, ['updated']);
+                       $updated = $contact['updated'] ?? '';
+               }
+
                $url = DI::baseUrl() . '/photo/contact/';
                switch ($size) {
                        case Proxy::SIZE_MICRO:
@@ -1685,7 +1697,7 @@ class Contact
                                $url .= Proxy::PIXEL_LARGE . '/';
                                break;
                }
-               return $url . $cid;
+               return $url . $cid . ($updated ? '?ts=' . strtotime($updated) : '');
        }
 
        /**
@@ -1700,19 +1712,47 @@ class Contact
        {
                $condition = ["`nurl` = ? AND ((`uid` = ? AND `network` IN (?, ?)) OR `uid` = ?)",
                        Strings::normaliseLink($url), $uid, Protocol::FEED, Protocol::MAIL, 0];
-               $contact = self::selectFirst(['id'], $condition);
-               return self::getAvatarUrlForId($contact['id'] ?? 0, $size);
+               $contact = self::selectFirst(['id', 'updated'], $condition);
+               return self::getAvatarUrlForId($contact['id'] ?? 0, $size, $contact['updated']);
        }
 
        /**
         * Get header link for given contact id
         *
-        * @param integer $cid contact id
+        * @param integer $cid     contact id
+        * @param string  $size    One of the ProxyUtils::SIZE_* constants
+        * @param string  $updated Contact update date
         * @return string header link
         */
-       public static function getHeaderUrlForId(int $cid):string
+       public static function getHeaderUrlForId(int $cid, string $size = '', string $updated = ''):string
        {
-               return DI::baseUrl() . '/photo/header/' . $cid;
+               // We have to fetch the "updated" variable when it wasn't provided
+               // The parameter can be provided to improve performance
+               if (empty($updated)) {
+                       $contact = self::getById($cid, ['updated']);
+                       $updated = $contact['updated'] ?? '';
+               }
+
+               $url = DI::baseUrl() . '/photo/header/';
+               switch ($size) {
+                       case Proxy::SIZE_MICRO:
+                               $url .= Proxy::PIXEL_MICRO . '/';
+                               break;
+                       case Proxy::SIZE_THUMB:
+                               $url .= Proxy::PIXEL_THUMB . '/';
+                               break;
+                       case Proxy::SIZE_SMALL:
+                               $url .= Proxy::PIXEL_SMALL . '/';
+                               break;
+                       case Proxy::SIZE_MEDIUM:
+                               $url .= Proxy::PIXEL_MEDIUM . '/';
+                               break;
+                       case Proxy::SIZE_LARGE:
+                               $url .= Proxy::PIXEL_LARGE . '/';
+                               break;
+               }
+
+               return $url . $cid . ($updated ? '?ts=' . strtotime($updated) : '');
        }
 
        /**
index b8a5bc822393a06028b92e847caa1a0ff55895a0..4aacc9f9b6341c37692e216447919d005d005974 100644 (file)
@@ -507,9 +507,9 @@ class Profile
                        $p['address'] = BBCode::convert($p['address']);
                }
 
-               $p['photo'] = Contact::getAvatarUrlForId($cid);
+               $p['photo'] = Contact::getAvatarUrlForId($cid, ProxyUtils::SIZE_SMALL);
 
-               $p['url'] = Contact::magicLink($profile_url);
+               $p['url'] = Contact::magicLinkById($cid);
 
                $tpl = Renderer::getMarkupTemplate('profile/vcard.tpl');
                $o .= Renderer::replaceMacros($tpl, [
index 2ea9da70482358bd4b232e66e4618c2f9bd5095f..d2053647a5a9a074c7608dff8e5e9a3906a331db 100644 (file)
@@ -28,6 +28,7 @@ use Friendica\Content\Text\BBCode;
 use Friendica\Database\DBA;
 use Friendica\Model\Contact;
 use Friendica\Util\DateTimeFormat;
+use Friendica\Util\Proxy;
 
 /**
  * Class Account
@@ -112,9 +113,9 @@ class Account extends BaseDataTransferObject
 
                $this->note            = BBCode::convert($publicContact['about'], false);
                $this->url             = $publicContact['url'];
-               $this->avatar          = $userContact['photo'] ?? '' ?: $publicContact['photo'] ?: Contact::getAvatarUrlForId($userContact['id'] ?? 0 ?: $publicContact['id']);
+               $this->avatar          = Contact::getAvatarUrlForId($userContact['id'] ?? 0 ?: $publicContact['id'], Proxy::SIZE_SMALL, $userContact['updated'] ?? '' ?: $publicContact['updated']);
                $this->avatar_static   = $this->avatar;
-               $this->header          = Contact::getHeaderUrlForId($userContact['id'] ?? 0 ?: $publicContact['id']);
+               $this->header          = Contact::getHeaderUrlForId($userContact['id'] ?? 0 ?: $publicContact['id'], '', $userContact['updated'] ?? '' ?: $publicContact['updated']);
                $this->header_static   = $this->header;
                $this->followers_count = $apcontact['followers_count'] ?? 0;
                $this->following_count = $apcontact['following_count'] ?? 0;