diff --git a/src/DI.php b/src/DI.php index 24f06d279..78eb5bee4 100644 --- a/src/DI.php +++ b/src/DI.php @@ -382,14 +382,6 @@ abstract class DI return self::$dice->create(Factory\Api\Mastodon\Error::class); } - /** - * @return Factory\Api\Mastodon\FollowRequest - */ - public static function mstdnFollowRequest() - { - return self::$dice->create(Factory\Api\Mastodon\FollowRequest::class); - } - /** * @return Factory\Api\Mastodon\Poll */ diff --git a/src/Factory/Api/Mastodon/FollowRequest.php b/src/Factory/Api/Mastodon/FollowRequest.php deleted file mode 100644 index 5674196a9..000000000 --- a/src/Factory/Api/Mastodon/FollowRequest.php +++ /dev/null @@ -1,61 +0,0 @@ -. - * - */ - -namespace Friendica\Factory\Api\Mastodon; - -use Friendica\App\BaseURL; -use Friendica\BaseFactory; -use Friendica\Collection\Api\Mastodon\Fields; -use Friendica\Contact\Introduction\Entity\Introduction; -use Friendica\Database\DBA; -use Friendica\Network\HTTPException; -use ImagickException; -use Psr\Log\LoggerInterface; - -class FollowRequest extends BaseFactory -{ - /** @var BaseURL */ - private $baseUrl; - - public function __construct(LoggerInterface $logger, BaseURL $baseURL) - { - parent::__construct($logger); - - $this->baseUrl = $baseURL; - } - - /** - * @param Introduction $introduction - * @return \Friendica\Object\Api\Mastodon\Account - * @throws ImagickException|HTTPException\InternalServerErrorException - */ - public function createFromIntroduction(Introduction $introduction): \Friendica\Object\Api\Mastodon\Account - { - $account = DBA::selectFirst('account-user-view', [], ['id' => $introduction->cid, - 'uid' => [0, $introduction->uid]]); - if (empty($account)) { - $this->logger->warning('Wrong introduction data', ['Introduction' => $introduction]); - throw new HTTPException\InternalServerErrorException('Wrong introduction data'); - } - - return new \Friendica\Object\Api\Mastodon\Account($this->baseUrl, $account, new Fields()); - } -} diff --git a/src/Module/Api/Mastodon/FollowRequests.php b/src/Module/Api/Mastodon/FollowRequests.php index 723a98bcd..dfe3aadf3 100644 --- a/src/Module/Api/Mastodon/FollowRequests.php +++ b/src/Module/Api/Mastodon/FollowRequests.php @@ -105,8 +105,10 @@ class FollowRequests extends BaseApi foreach ($introductions as $key => $introduction) { try { self::setBoundaries($introduction->id); - $return[] = DI::mstdnFollowRequest()->createFromIntroduction($introduction); - } catch (HTTPException\InternalServerErrorException $exception) { + $return[] = DI::mstdnAccount()->createFromContactId($introduction->cid, $introduction->uid); + } catch (HTTPException\InternalServerErrorException + | HTTPException\NotFoundException + | \ImagickException $exception) { DI::intro()->delete($introduction); unset($introductions[$key]); }