| 
									
										
										
										
											2021-06-26 23:23:15 +08:00
										 |  |  | <?php | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-05-18 00:56:55 +08:00
										 |  |  | namespace BookStack\Entities\Controllers; | 
					
						
							| 
									
										
										
										
											2020-02-23 13:41:49 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-11-22 08:17:45 +08:00
										 |  |  | use BookStack\Entities\Models\Bookshelf; | 
					
						
							| 
									
										
										
										
											2024-02-08 05:58:27 +08:00
										 |  |  | use BookStack\Entities\Queries\BookshelfQueries; | 
					
						
							| 
									
										
										
										
											2021-06-26 23:23:15 +08:00
										 |  |  | use BookStack\Entities\Repos\BookshelfRepo; | 
					
						
							| 
									
										
										
										
											2023-05-19 03:53:39 +08:00
										 |  |  | use BookStack\Http\ApiController; | 
					
						
							| 
									
										
										
										
											2020-02-23 13:41:49 +08:00
										 |  |  | use Exception; | 
					
						
							| 
									
										
										
										
											2020-04-10 22:19:18 +08:00
										 |  |  | use Illuminate\Database\Eloquent\Relations\BelongsToMany; | 
					
						
							| 
									
										
										
										
											2020-02-23 13:41:49 +08:00
										 |  |  | use Illuminate\Http\Request; | 
					
						
							|  |  |  | use Illuminate\Validation\ValidationException; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class BookshelfApiController extends ApiController | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2023-12-21 21:23:52 +08:00
										 |  |  |     public function __construct( | 
					
						
							| 
									
										
										
										
											2024-02-08 05:58:27 +08:00
										 |  |  |         protected BookshelfRepo $bookshelfRepo, | 
					
						
							|  |  |  |         protected BookshelfQueries $queries, | 
					
						
							| 
									
										
										
										
											2023-12-21 21:23:52 +08:00
										 |  |  |     ) { | 
					
						
							| 
									
										
										
										
											2020-02-23 13:41:49 +08:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * Get a listing of shelves visible to the user. | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function list() | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2024-02-11 23:42:37 +08:00
										 |  |  |         $shelves = $this->queries | 
					
						
							|  |  |  |             ->visibleForList() | 
					
						
							| 
									
										
										
										
											2024-12-13 22:21:04 +08:00
										 |  |  |             ->with(['cover:id,name,url']) | 
					
						
							| 
									
										
										
										
											2024-02-11 23:42:37 +08:00
										 |  |  |             ->addSelect(['created_by', 'updated_by']); | 
					
						
							| 
									
										
										
										
											2021-06-26 23:23:15 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-02-23 13:41:49 +08:00
										 |  |  |         return $this->apiListingResponse($shelves, [ | 
					
						
							| 
									
										
										
										
											2022-06-07 21:27:45 +08:00
										 |  |  |             'id', 'name', 'slug', 'description', 'created_at', 'updated_at', 'created_by', 'updated_by', 'owned_by', | 
					
						
							| 
									
										
										
										
											2020-02-23 13:41:49 +08:00
										 |  |  |         ]); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * Create a new shelf in the system. | 
					
						
							| 
									
										
										
										
											2020-04-10 22:19:18 +08:00
										 |  |  |      * An array of books IDs can be provided in the request. These | 
					
						
							|  |  |  |      * will be added to the shelf in the same order as provided. | 
					
						
							| 
									
										
										
										
											2022-06-20 00:26:23 +08:00
										 |  |  |      * The cover image of a shelf can be set by sending a file via an 'image' property within a 'multipart/form-data' request. | 
					
						
							|  |  |  |      * If the 'image' property is null then the shelf cover image will be removed. | 
					
						
							| 
									
										
										
										
											2021-06-26 23:23:15 +08:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2020-02-23 13:41:49 +08:00
										 |  |  |      * @throws ValidationException | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function create(Request $request) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $this->checkPermission('bookshelf-create-all'); | 
					
						
							| 
									
										
										
										
											2022-06-20 00:26:23 +08:00
										 |  |  |         $requestData = $this->validate($request, $this->rules()['create']); | 
					
						
							| 
									
										
										
										
											2020-02-23 13:41:49 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |         $bookIds = $request->get('books', []); | 
					
						
							| 
									
										
										
										
											2020-04-10 22:19:18 +08:00
										 |  |  |         $shelf = $this->bookshelfRepo->create($requestData, $bookIds); | 
					
						
							| 
									
										
										
										
											2020-02-23 13:41:49 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-12-21 21:23:52 +08:00
										 |  |  |         return response()->json($this->forJsonDisplay($shelf)); | 
					
						
							| 
									
										
										
										
											2020-02-23 13:41:49 +08:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * View the details of a single shelf. | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function read(string $id) | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2024-02-08 05:58:27 +08:00
										 |  |  |         $shelf = $this->queries->findVisibleByIdOrFail(intval($id)); | 
					
						
							| 
									
										
										
										
											2023-12-21 21:23:52 +08:00
										 |  |  |         $shelf = $this->forJsonDisplay($shelf); | 
					
						
							|  |  |  |         $shelf->load([ | 
					
						
							|  |  |  |             'createdBy', 'updatedBy', 'ownedBy', | 
					
						
							| 
									
										
										
										
											2020-04-10 22:19:18 +08:00
										 |  |  |             'books' => function (BelongsToMany $query) { | 
					
						
							| 
									
										
										
										
											2021-11-23 07:33:55 +08:00
										 |  |  |                 $query->scopes('visible')->get(['id', 'name', 'slug']); | 
					
						
							| 
									
										
										
										
											2021-06-26 23:23:15 +08:00
										 |  |  |             }, | 
					
						
							| 
									
										
										
										
											2023-12-21 21:23:52 +08:00
										 |  |  |         ]); | 
					
						
							| 
									
										
										
										
											2021-06-26 23:23:15 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-02-23 13:41:49 +08:00
										 |  |  |         return response()->json($shelf); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * Update the details of a single shelf. | 
					
						
							| 
									
										
										
										
											2020-04-10 22:19:18 +08:00
										 |  |  |      * An array of books IDs can be provided in the request. These | 
					
						
							|  |  |  |      * will be added to the shelf in the same order as provided and overwrite | 
					
						
							|  |  |  |      * any existing book assignments. | 
					
						
							| 
									
										
										
										
											2022-06-20 00:26:23 +08:00
										 |  |  |      * The cover image of a shelf can be set by sending a file via an 'image' property within a 'multipart/form-data' request. | 
					
						
							|  |  |  |      * If the 'image' property is null then the shelf cover image will be removed. | 
					
						
							| 
									
										
										
										
											2021-06-26 23:23:15 +08:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2020-02-23 13:41:49 +08:00
										 |  |  |      * @throws ValidationException | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function update(Request $request, string $id) | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2024-02-08 05:58:27 +08:00
										 |  |  |         $shelf = $this->queries->findVisibleByIdOrFail(intval($id)); | 
					
						
							| 
									
										
										
										
											2020-02-23 13:41:49 +08:00
										 |  |  |         $this->checkOwnablePermission('bookshelf-update', $shelf); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-06-20 00:26:23 +08:00
										 |  |  |         $requestData = $this->validate($request, $this->rules()['update']); | 
					
						
							| 
									
										
										
										
											2020-04-10 22:19:18 +08:00
										 |  |  |         $bookIds = $request->get('books', null); | 
					
						
							| 
									
										
										
										
											2020-02-23 13:41:49 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-04-10 22:19:18 +08:00
										 |  |  |         $shelf = $this->bookshelfRepo->update($shelf, $requestData, $bookIds); | 
					
						
							| 
									
										
										
										
											2021-06-26 23:23:15 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-12-21 21:23:52 +08:00
										 |  |  |         return response()->json($this->forJsonDisplay($shelf)); | 
					
						
							| 
									
										
										
										
											2020-02-23 13:41:49 +08:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							| 
									
										
										
										
											2020-11-28 23:21:54 +08:00
										 |  |  |      * Delete a single shelf. | 
					
						
							|  |  |  |      * This will typically send the shelf to the recycle bin. | 
					
						
							| 
									
										
										
										
											2021-06-26 23:23:15 +08:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2020-02-23 13:41:49 +08:00
										 |  |  |      * @throws Exception | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function delete(string $id) | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2024-02-08 05:58:27 +08:00
										 |  |  |         $shelf = $this->queries->findVisibleByIdOrFail(intval($id)); | 
					
						
							| 
									
										
										
										
											2020-02-23 13:41:49 +08:00
										 |  |  |         $this->checkOwnablePermission('bookshelf-delete', $shelf); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $this->bookshelfRepo->destroy($shelf); | 
					
						
							| 
									
										
										
										
											2021-06-26 23:23:15 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-02-23 13:41:49 +08:00
										 |  |  |         return response('', 204); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2022-06-14 00:20:21 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-12-21 21:23:52 +08:00
										 |  |  |     protected function forJsonDisplay(Bookshelf $shelf): Bookshelf | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $shelf = clone $shelf; | 
					
						
							|  |  |  |         $shelf->unsetRelations()->refresh(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $shelf->load(['tags', 'cover']); | 
					
						
							|  |  |  |         $shelf->makeVisible('description_html') | 
					
						
							|  |  |  |             ->setAttribute('description_html', $shelf->descriptionHtml()); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return $shelf; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-06-14 00:20:21 +08:00
										 |  |  |     protected function rules(): array | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return [ | 
					
						
							|  |  |  |             'create' => [ | 
					
						
							| 
									
										
										
										
											2023-12-21 21:23:52 +08:00
										 |  |  |                 'name'             => ['required', 'string', 'max:255'], | 
					
						
							|  |  |  |                 'description'      => ['string', 'max:1900'], | 
					
						
							|  |  |  |                 'description_html' => ['string', 'max:2000'], | 
					
						
							|  |  |  |                 'books'            => ['array'], | 
					
						
							|  |  |  |                 'tags'             => ['array'], | 
					
						
							|  |  |  |                 'image'            => array_merge(['nullable'], $this->getImageValidationRules()), | 
					
						
							| 
									
										
										
										
											2022-06-14 00:20:21 +08:00
										 |  |  |             ], | 
					
						
							|  |  |  |             'update' => [ | 
					
						
							| 
									
										
										
										
											2023-12-21 21:23:52 +08:00
										 |  |  |                 'name'             => ['string', 'min:1', 'max:255'], | 
					
						
							|  |  |  |                 'description'      => ['string', 'max:1900'], | 
					
						
							|  |  |  |                 'description_html' => ['string', 'max:2000'], | 
					
						
							|  |  |  |                 'books'            => ['array'], | 
					
						
							|  |  |  |                 'tags'             => ['array'], | 
					
						
							|  |  |  |                 'image'            => array_merge(['nullable'], $this->getImageValidationRules()), | 
					
						
							| 
									
										
										
										
											2022-06-14 00:20:21 +08:00
										 |  |  |             ], | 
					
						
							|  |  |  |         ]; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2021-03-08 06:24:05 +08:00
										 |  |  | } |