X-Git-Url: http://source.bookstackapp.com/bookstack/blobdiff_plain/d2eec4fbcef7f604e7afc01cd87286670c3f75c8..a87ae1601061322e7e7b2dc11658f56467761787:/app/Http/Controllers/ImageController.php diff --git a/app/Http/Controllers/ImageController.php b/app/Http/Controllers/ImageController.php index d71e38346..df7758176 100644 --- a/app/Http/Controllers/ImageController.php +++ b/app/Http/Controllers/ImageController.php @@ -1,13 +1,12 @@ imageRepo->getPaginatedByType($type, $page); + $uploadedToFilter = $request->get('uploaded_to', null); + + // For user profile request, check access to user images + if ($type === 'user') { + $this->checkPermissionOrCurrentUser('users-manage', $uploadedToFilter ?? 0); + } + + $imgData = $this->imageRepo->getPaginatedByType($type, $page, 24, $uploadedToFilter); return response()->json($imgData); } @@ -74,87 +81,38 @@ class ImageController extends Controller return response()->json($imgData); } - /** - * Get all images for a user. - * @param int $page - * @return \Illuminate\Http\JsonResponse - */ - public function getAllForUserType($page = 0) + public function uploadUserImage(Request $request) { - $imgData = $this->imageRepo->getPaginatedByType('user', $page, 24, $this->currentUser->id); - return response()->json($imgData); + // TODO } - /** - * Get gallery images with a specific filter such as book or page - * @param $filter - * @param int $page - * @param Request $request - * @return \Illuminate\Contracts\Routing\ResponseFactory|\Illuminate\Http\JsonResponse|\Symfony\Component\HttpFoundation\Response - */ - public function getGalleryFiltered(Request $request, $filter, $page = 0) + public function uploadSystemImage(Request $request) { - $this->validate($request, [ - 'page_id' => 'required|integer' - ]); - - $validFilters = collect(['page', 'book']); - if (!$validFilters->contains($filter)) { - return response('Invalid filter', 500); - } - - $pageId = $request->get('page_id'); - $imgData = $this->imageRepo->getGalleryFiltered(strtolower($filter), $pageId, $page, 24); - - return response()->json($imgData); + // TODO } - /** - * Handles image uploads for use on pages. - * @param string $type - * @param Request $request - * @return \Illuminate\Http\JsonResponse - * @throws \Exception - */ - public function uploadByType($type, Request $request) + public function uploadCoverImage(Request $request) { - $this->checkPermission('image-create-all'); - $this->validate($request, [ - 'file' => 'required|is_image' - ]); - - if (!$this->imageRepo->isValidType($type)) { - return $this->jsonError(trans('errors.image_upload_type_error')); - } - - $imageUpload = $request->file('file'); - - try { - $uploadedTo = $request->get('uploaded_to', 0); - $image = $this->imageRepo->saveNew($imageUpload, $type, $uploadedTo); - } catch (ImageUploadException $e) { - return response($e->getMessage(), 500); - } - - return response()->json($image); + // TODO } /** - * Upload a drawing to the system. + * Upload a draw.io image into the system. * @param Request $request * @return \Illuminate\Contracts\Routing\ResponseFactory|\Illuminate\Http\JsonResponse|\Symfony\Component\HttpFoundation\Response */ - public function uploadDrawing(Request $request) + public function uploadDrawioImage(Request $request) { $this->validate($request, [ 'image' => 'required|string', 'uploaded_to' => 'required|integer' ]); + $uploadedTo = $request->get('uploaded_to', 0); + $page = $this-> $this->checkPermission('image-create-all'); $imageBase64Data = $request->get('image'); try { - $uploadedTo = $request->get('uploaded_to', 0); $image = $this->imageRepo->saveDrawing($imageBase64Data, $uploadedTo); } catch (ImageUploadException $e) { return response($e->getMessage(), 500); @@ -164,31 +122,40 @@ class ImageController extends Controller } /** - * Replace the data content of a drawing. - * @param string $id + * Handles image uploads for use on pages. + * @param string $type * @param Request $request - * @return \Illuminate\Contracts\Routing\ResponseFactory|\Illuminate\Http\JsonResponse|\Symfony\Component\HttpFoundation\Response + * @return \Illuminate\Http\JsonResponse + * @throws \Exception */ - public function replaceDrawing(string $id, Request $request) + public function uploadByType($type, Request $request) { + $this->checkPermission('image-create-all'); $this->validate($request, [ - 'image' => 'required|string' + 'file' => 'image_extension|no_double_extension|mimes:jpeg,png,gif,bmp,webp,tiff' ]); - $this->checkPermission('image-create-all'); - $imageBase64Data = $request->get('image'); - $image = $this->imageRepo->getById($id); - $this->checkOwnablePermission('image-update', $image); + if (!$this->imageRepo->isValidType($type)) { + return $this->jsonError(trans('errors.image_upload_type_error')); + } + + $imageUpload = $request->file('file'); try { - $image = $this->imageRepo->replaceDrawingContent($image, $imageBase64Data); + $uploadedTo = $request->get('uploaded_to', 0); + + // For user profile request, check access to user images + if ($type === 'user') { + $this->checkPermissionOrCurrentUser('users-manage', $uploadedTo ?? 0); + } + + $image = $this->imageRepo->saveNew($imageUpload, $type, $uploadedTo); } catch (ImageUploadException $e) { return response($e->getMessage(), 500); } return response()->json($image); } - /** * Get the content of an image based64 encoded. * @param $id @@ -226,44 +193,49 @@ class ImageController extends Controller /** * Update image details - * @param integer $imageId + * @param integer $id * @param Request $request * @return \Illuminate\Http\JsonResponse * @throws ImageUploadException * @throws \Exception */ - public function update($imageId, Request $request) + public function update($id, Request $request) { $this->validate($request, [ 'name' => 'required|min:2|string' ]); - $image = $this->imageRepo->getById($imageId); + + $image = $this->imageRepo->getById($id); $this->checkOwnablePermission('image-update', $image); + $image = $this->imageRepo->updateImageDetails($image, $request->all()); return response()->json($image); } + /** + * Show the usage of an image on pages. + * @param \BookStack\Entities\Repos\EntityRepo $entityRepo + * @param $id + * @return \Illuminate\Http\JsonResponse + */ + public function usage(EntityRepo $entityRepo, $id) + { + $image = $this->imageRepo->getById($id); + $pageSearch = $entityRepo->searchForImage($image->url); + return response()->json($pageSearch); + } + /** * Deletes an image and all thumbnail/image files - * @param EntityRepo $entityRepo - * @param Request $request * @param int $id * @return \Illuminate\Http\JsonResponse + * @throws \Exception */ - public function destroy(EntityRepo $entityRepo, Request $request, $id) + public function destroy($id) { $image = $this->imageRepo->getById($id); $this->checkOwnablePermission('image-delete', $image); - // Check if this image is used on any pages - $isForced = in_array($request->get('force', ''), [true, 'true']); - if (!$isForced) { - $pageSearch = $entityRepo->searchForImage($image->url); - if ($pageSearch !== false) { - return response()->json($pageSearch, 400); - } - } - $this->imageRepo->destroyImage($image); return response()->json(trans('components.images_deleted')); }