* @param array $condition condition array with the key values
* @param array|boolean $old_fields array with the old field values that are about to be replaced (true = update on duplicate, false = don't update identical fields)
*
- * @return boolean was the update successfull?
+ * @return boolean was the update successful?
* @throws \Exception
* @todo Let's get rid of boolean type of $old_fields
*/
* Unblocks a contact
*
* @param int $cid Contact id to unblock
- * @return bool Whether it was successfull
+ * @return bool Whether it was successful
*/
public static function unblock(int $cid): bool
{
*
* @param array $contact contact array
* @param string $size Size of the avatar picture
- * @param bool $no_update Don't perfom an update if no cached avatar was found
+ * @param bool $no_update Don't perform an update if no cached avatar was found
* @return string photo path
*/
private static function getAvatarPath(array $contact, string $size, bool $no_update = false): string
* Return the photo path for a given contact array
*
* @param array $contact Contact array
- * @param bool $no_update Don't perfom an update if no cached avatar was found
+ * @param bool $no_update Don't perform an update if no cached avatar was found
* @return string photo path
*/
public static function getPhoto(array $contact, bool $no_update = false): string
* Return the photo path (thumb size) for a given contact array
*
* @param array $contact Contact array
- * @param bool $no_update Don't perfom an update if no cached avatar was found
+ * @param bool $no_update Don't perform an update if no cached avatar was found
* @return string photo path
*/
public static function getThumb(array $contact, bool $no_update = false): string
* Return the photo path (micro size) for a given contact array
*
* @param array $contact Contact array
- * @param bool $no_update Don't perfom an update if no cached avatar was found
+ * @param bool $no_update Don't perform an update if no cached avatar was found
* @return string photo path
*/
public static function getMicro(array $contact, bool $no_update = false): string
* Check the given contact array for avatar cache fields
*
* @param array $contact
- * @param bool $no_update Don't perfom an update if no cached avatar was found
+ * @param bool $no_update Don't perform an update if no cached avatar was found
* @return array contact array with avatar cache fields
*/
private static function checkAvatarCacheByArray(array $contact, bool $no_update = false): array
if (($contact['avatar'] != $avatar) || empty($contact['blurhash'])) {
$update_fields = ['avatar' => $avatar];
if (!Network::isLocalLink($avatar)) {
- $fetchResult = HTTPSignature::fetchRaw($avatar, 0, [HttpClientOptions::ACCEPT_CONTENT => [HttpClientAccept::IMAGE]]);
-
- $img_str = $fetchResult->getBody();
- if (!empty($img_str)) {
- $image = new Image($img_str, Images::getMimeTypeByData($img_str));
- if ($image->isValid()) {
- $update_fields['blurhash'] = $image->getBlurHash();
- } else {
- return;
+ try {
+ $fetchResult = HTTPSignature::fetchRaw($avatar, 0, [HttpClientOptions::ACCEPT_CONTENT => [HttpClientAccept::IMAGE]]);
+
+ $img_str = $fetchResult->getBody();
+ if (!empty($img_str)) {
+ $image = new Image($img_str, Images::getMimeTypeByData($img_str));
+ if ($image->isValid()) {
+ $update_fields['blurhash'] = $image->getBlurHash();
+ } else {
+ return;
+ }
}
+ } catch (\Exception $exception) {
+ Logger::notice('Error fetching avatar', ['avatar' => $avatar, 'exception' => $exception]);
+ return;
}
} elseif (!empty($contact['blurhash'])) {
$update_fields['blurhash'] = null;