]> git.mxchange.org Git - friendica.git/blobdiff - src/Worker/AddContact.php
Merge pull request #12951 from jsoref/spelling
[friendica.git] / src / Worker / AddContact.php
index 755373fcd019a40a67ff81a00f44baf8b94c5f98..b27c54ed76f885d889f61cc5d3687aecc1ad210a 100644 (file)
@@ -1,6 +1,6 @@
 <?php
 /**
- * @copyright Copyright (C) 2010-2021, the Friendica project
+ * @copyright Copyright (C) 2010-2023, the Friendica project
  *
  * @license GNU AGPL version 3 or any later version
  *
 
 namespace Friendica\Worker;
 
-use Friendica\Core\Logger;
+use Friendica\DI;
 use Friendica\Model\Contact;
+use Friendica\Network\HTTPException\InternalServerErrorException;
+use Friendica\Network\HTTPException\NotFoundException;
 
 class AddContact
 {
@@ -33,14 +35,22 @@ class AddContact
         */
        public static function execute(int $uid, string $url)
        {
-               if ($uid == 0) {
-                       // Adding public contact
-                       $result = Contact::getIdForURL($url);
-                       Logger::info('Added public contact', ['url' => $url, 'result' => $result]);
-                       return;
-               }
+               try {
+                       if ($uid == 0) {
+                               // Adding public contact
+                               $result = Contact::getIdForURL($url);
+                               DI::logger()->info('Added public contact', ['url' => $url, 'result' => $result]);
+                               return;
+                       }
 
-               $result = Contact::createFromProbe($uid, $url);
-               Logger::info('Added contact', ['uid' => $uid, 'url' => $url, 'result' => $result]);
+                       $result = Contact::createFromProbeForUser($uid, $url);
+                       DI::logger()->info('Added contact for user', ['uid' => $uid, 'url' => $url, 'result' => $result]);
+               } catch (InternalServerErrorException $e) {
+                       DI::logger()->warning('Internal server error.', ['exception' => $e, 'uid' => $uid, 'url' => $url]);
+               } catch (NotFoundException $e) {
+                       DI::logger()->notice('uid not found.', ['exception' => $e, 'uid' => $uid, 'url' => $url]);
+               } catch (\ImagickException $e) {
+                       DI::logger()->notice('Imagick not found.', ['exception' => $e, 'uid' => $uid, 'url' => $url]);
+               }
        }
 }