From f44c9e7975db6ee7504db36cb5baaecd82366f8a Mon Sep 17 00:00:00 2001 From: Michael Date: Sat, 29 Oct 2022 19:04:29 +0000 Subject: [PATCH] Accepting contact request does finally work per Mastodon API --- src/Factory/Api/Mastodon/Notification.php | 5 ++++- src/Module/Api/Mastodon/FollowRequests.php | 7 ++++++- 2 files changed, 10 insertions(+), 2 deletions(-) diff --git a/src/Factory/Api/Mastodon/Notification.php b/src/Factory/Api/Mastodon/Notification.php index 33c252e4f..3e43835b4 100644 --- a/src/Factory/Api/Mastodon/Notification.php +++ b/src/Factory/Api/Mastodon/Notification.php @@ -83,7 +83,10 @@ class Notification extends BaseFactory public static function getType(Entity\Notification $Notification): string { if (($Notification->verb == Activity::FOLLOW) && ($Notification->type === Post\UserNotification::TYPE_NONE)) { - $contact = Contact::getById($Notification->actorId, ['pending']); + $contact = Contact::getById($Notification->actorId, ['pending', 'uri-id', 'uid']); + if (($contact['uid'] == 0) && !empty($contact['uri-id'])) { + $contact = Contact::selectFirst(['pending', 'uri-id', 'uid'], ['uri-id' => $contact['uri-id'], 'uid' => $Notification->uid]); + } $type = $contact['pending'] ? MstdnNotification::TYPE_INTRODUCTION : MstdnNotification::TYPE_FOLLOW; } elseif (($Notification->verb == Activity::ANNOUNCE) && in_array($Notification->type, [Post\UserNotification::TYPE_DIRECT_COMMENT, Post\UserNotification::TYPE_DIRECT_THREAD_COMMENT])) { diff --git a/src/Module/Api/Mastodon/FollowRequests.php b/src/Module/Api/Mastodon/FollowRequests.php index 99e20cd7f..af08517e9 100644 --- a/src/Module/Api/Mastodon/FollowRequests.php +++ b/src/Module/Api/Mastodon/FollowRequests.php @@ -47,7 +47,12 @@ class FollowRequests extends BaseApi self::checkAllowedScope(self::SCOPE_FOLLOW); $uid = self::getCurrentUserID(); - $introduction = DI::intro()->selectOneById($this->parameters['id'], $uid); + $cdata = Contact::getPublicAndUserContactID($this->parameters['id'], $uid); + if (empty($cdata['user'])) { + throw new HTTPException\NotFoundException('Contact not found'); + } + + $introduction = DI::intro()->selectForContact($cdata['user']); $contactId = $introduction->cid;