From c74cd0bdf0155ad07baf3e79e04a09437575626a Mon Sep 17 00:00:00 2001 From: Daniel Supernault Date: Tue, 19 May 2020 14:55:26 -0600 Subject: [PATCH] Add missing bookmark api endpoints --- app/Http/Controllers/Api/ApiV1Controller.php | 53 ++++++++++++++++++++ routes/api.php | 2 + 2 files changed, 55 insertions(+) diff --git a/app/Http/Controllers/Api/ApiV1Controller.php b/app/Http/Controllers/Api/ApiV1Controller.php index 14074ec22..21b4321e8 100644 --- a/app/Http/Controllers/Api/ApiV1Controller.php +++ b/app/Http/Controllers/Api/ApiV1Controller.php @@ -1901,6 +1901,59 @@ class ApiV1Controller extends Controller return response()->json($res, 200, [], JSON_PRETTY_PRINT|JSON_UNESCAPED_SLASHES); } + /** + * POST /api/v1/statuses/{id}/bookmark + * + * + * + * @return StatusTransformer + */ + public function bookmarkStatus(Request $request, $id) + { + abort_if(!$request->user(), 403); + + $status = Status::whereNull('uri') + ->whereScope('public') + ->findOrFail($id); + + Bookmark::firstOrCreate([ + 'status_id' => $status->id, + 'profile_id' => $request->user()->profile_id + ]); + $resource = new Fractal\Resource\Item($status, new StatusTransformer()); + $res = $this->fractal->createData($resource)->toArray(); + return response()->json($res); + } + + /** + * POST /api/v1/statuses/{id}/unbookmark + * + * + * + * @return StatusTransformer + */ + public function unbookmarkStatus(Request $request, $id) + { + abort_if(!$request->user(), 403); + + $status = Status::whereNull('uri') + ->whereScope('public') + ->findOrFail($id); + + Bookmark::firstOrCreate([ + 'status_id' => $status->id, + 'profile_id' => $request->user()->profile_id + ]); + $bookmark = Bookmark::whereStatusId($status->id) + ->whereProfileId($request->user()->profile_id) + ->firstOrFail(); + $bookmark->delete(); + + $resource = new Fractal\Resource\Item($status, new StatusTransformer()); + $res = $this->fractal->createData($resource)->toArray(); + return response()->json($res); + } + /** * GET /api/v2/search * diff --git a/routes/api.php b/routes/api.php index 10f032d9e..0ed69b425 100644 --- a/routes/api.php +++ b/routes/api.php @@ -60,6 +60,8 @@ Route::group(['prefix' => 'api'], function() use($middleware) { Route::get('statuses/{id}/favourited_by', 'Api\ApiV1Controller@statusFavouritedBy')->middleware($middleware); Route::post('statuses/{id}/reblog', 'Api\ApiV1Controller@statusShare')->middleware($middleware); Route::post('statuses/{id}/unreblog', 'Api\ApiV1Controller@statusUnshare')->middleware($middleware); + Route::post('statuses/{id}/bookmark', 'Api\ApiV1Controller@bookmarkStatus')->middleware($middleware); + Route::post('statuses/{id}/unbookmark', 'Api\ApiV1Controller@unbookmarkStatus')->middleware($middleware); Route::delete('statuses/{id}', 'Api\ApiV1Controller@statusDelete')->middleware($middleware); Route::get('statuses/{id}', 'Api\ApiV1Controller@statusById')->middleware($middleware); Route::post('statuses', 'Api\ApiV1Controller@statusCreate')->middleware($middleware)->middleware('throttle:maxPostsPerHour,60')->middleware('throttle:maxPostsPerDay,1440');