diff --git a/src/Module/Api/Mastodon/Statuses/Bookmark.php b/src/Module/Api/Mastodon/Statuses/Bookmark.php index f33b88728..95a072889 100644 --- a/src/Module/Api/Mastodon/Statuses/Bookmark.php +++ b/src/Module/Api/Mastodon/Statuses/Bookmark.php @@ -42,7 +42,7 @@ class Bookmark extends BaseApi DI::mstdnError()->UnprocessableEntity(); } - $item = Post::selectFirstForUser($uid, ['id', 'gravity'], ['uri-id' => $this->parameters['id'], 'uid' => [$uid, 0]]); + $item = Post::selectFirst(['uid', 'id', 'gravity'], ['uri-id' => $this->parameters['id'], 'uid' => [$uid, 0]], ['order' => ['uid' => true]]); if (!DBA::isResult($item)) { DI::mstdnError()->RecordNotFound(); } @@ -51,6 +51,18 @@ class Bookmark extends BaseApi DI::mstdnError()->UnprocessableEntity(DI::l10n()->t('Only starting posts can be bookmarked')); } + if ($item['uid'] == 0) { + $stored = Item::storeForUserByUriId($this->parameters['id'], $uid); + if (!empty($stored)) { + $item = Post::selectFirst(['id', 'gravity'], ['id' => $stored]); + if (!DBA::isResult($item)) { + DI::mstdnError()->RecordNotFound(); + } + } else { + DI::mstdnError()->RecordNotFound(); + } + } + Item::update(['starred' => true], ['id' => $item['id']]); System::jsonExit(DI::mstdnStatus()->createFromUriId($this->parameters['id'], $uid)->toArray()); diff --git a/src/Module/Api/Mastodon/Statuses/Unbookmark.php b/src/Module/Api/Mastodon/Statuses/Unbookmark.php index 9dc9e73f9..103fac04a 100644 --- a/src/Module/Api/Mastodon/Statuses/Unbookmark.php +++ b/src/Module/Api/Mastodon/Statuses/Unbookmark.php @@ -42,7 +42,7 @@ class Unbookmark extends BaseApi DI::mstdnError()->UnprocessableEntity(); } - $item = Post::selectFirstForUser($uid, ['id', 'gravity'], ['uri-id' => $this->parameters['id'], 'uid' => [$uid, 0]]); + $item = Post::selectFirst(['uid', 'id', 'gravity'], ['uri-id' => $this->parameters['id'], 'uid' => [$uid, 0]], ['order' => ['uid' => true]]); if (!DBA::isResult($item)) { DI::mstdnError()->RecordNotFound(); } @@ -51,6 +51,18 @@ class Unbookmark extends BaseApi DI::mstdnError()->UnprocessableEntity(DI::l10n()->t('Only starting posts can be unbookmarked')); } + if ($item['uid'] == 0) { + $stored = Item::storeForUserByUriId($this->parameters['id'], $uid); + if (!empty($stored)) { + $item = Post::selectFirst(['id', 'gravity'], ['id' => $stored]); + if (!DBA::isResult($item)) { + DI::mstdnError()->RecordNotFound(); + } + } else { + DI::mstdnError()->RecordNotFound(); + } + } + Item::update(['starred' => false], ['id' => $item['id']]); System::jsonExit(DI::mstdnStatus()->createFromUriId($this->parameters['id'], $uid)->toArray());