]> BookStack Code Mirror - bookstack/blob - app/Http/Controllers/ImageController.php
Update Traditional Chinese
[bookstack] / app / Http / Controllers / ImageController.php
1 <?php namespace BookStack\Http\Controllers;
2
3 use BookStack\Exceptions\ImageUploadException;
4 use BookStack\Exceptions\NotFoundException;
5 use BookStack\Repos\EntityRepo;
6 use BookStack\Repos\ImageRepo;
7 use Illuminate\Filesystem\Filesystem as File;
8 use Illuminate\Http\Request;
9 use BookStack\Image;
10 use BookStack\Repos\PageRepo;
11
12 class ImageController extends Controller
13 {
14     protected $image;
15     protected $file;
16     protected $imageRepo;
17
18     /**
19      * ImageController constructor.
20      * @param Image $image
21      * @param File $file
22      * @param ImageRepo $imageRepo
23      */
24     public function __construct(Image $image, File $file, ImageRepo $imageRepo)
25     {
26         $this->image = $image;
27         $this->file = $file;
28         $this->imageRepo = $imageRepo;
29         parent::__construct();
30     }
31
32     /**
33      * Provide an image file from storage.
34      * @param string $path
35      * @return mixed
36      */
37     public function showImage(string $path)
38     {
39         $path = storage_path('uploads/images/' . $path);
40         if (!file_exists($path)) {
41             abort(404);
42         }
43
44         return response()->file($path);
45     }
46
47     /**
48      * Get all images for a specific type, Paginated
49      * @param string $type
50      * @param int $page
51      * @return \Illuminate\Http\JsonResponse
52      */
53     public function getAllByType($type, $page = 0)
54     {
55         $imgData = $this->imageRepo->getPaginatedByType($type, $page);
56         return response()->json($imgData);
57     }
58
59     /**
60      * Search through images within a particular type.
61      * @param $type
62      * @param int $page
63      * @param Request $request
64      * @return mixed
65      */
66     public function searchByType(Request $request, $type, $page = 0)
67     {
68         $this->validate($request, [
69             'term' => 'required|string'
70         ]);
71
72         $searchTerm = $request->get('term');
73         $imgData = $this->imageRepo->searchPaginatedByType($type, $searchTerm, $page, 24);
74         return response()->json($imgData);
75     }
76
77     /**
78      * Get all images for a user.
79      * @param int $page
80      * @return \Illuminate\Http\JsonResponse
81      */
82     public function getAllForUserType($page = 0)
83     {
84         $imgData = $this->imageRepo->getPaginatedByType('user', $page, 24, $this->currentUser->id);
85         return response()->json($imgData);
86     }
87
88     /**
89      * Get gallery images with a specific filter such as book or page
90      * @param $filter
91      * @param int $page
92      * @param Request $request
93      * @return \Illuminate\Contracts\Routing\ResponseFactory|\Illuminate\Http\JsonResponse|\Symfony\Component\HttpFoundation\Response
94      */
95     public function getGalleryFiltered(Request $request, $filter, $page = 0)
96     {
97         $this->validate($request, [
98             'page_id' => 'required|integer'
99         ]);
100
101         $validFilters = collect(['page', 'book']);
102         if (!$validFilters->contains($filter)) {
103             return response('Invalid filter', 500);
104         }
105
106         $pageId = $request->get('page_id');
107         $imgData = $this->imageRepo->getGalleryFiltered(strtolower($filter), $pageId, $page, 24);
108
109         return response()->json($imgData);
110     }
111
112     /**
113      * Handles image uploads for use on pages.
114      * @param string $type
115      * @param Request $request
116      * @return \Illuminate\Http\JsonResponse
117      * @throws \Exception
118      */
119     public function uploadByType($type, Request $request)
120     {
121         $this->checkPermission('image-create-all');
122         $this->validate($request, [
123             'file' => 'is_image'
124         ]);
125
126         if (!$this->imageRepo->isValidType($type)) {
127             return $this->jsonError(trans('errors.image_upload_type_error'));
128         }
129
130         $imageUpload = $request->file('file');
131
132         try {
133             $uploadedTo = $request->get('uploaded_to', 0);
134             $image = $this->imageRepo->saveNew($imageUpload, $type, $uploadedTo);
135         } catch (ImageUploadException $e) {
136             return response($e->getMessage(), 500);
137         }
138
139
140         return response()->json($image);
141     }
142
143     /**
144      * Upload a drawing to the system.
145      * @param Request $request
146      * @return \Illuminate\Contracts\Routing\ResponseFactory|\Illuminate\Http\JsonResponse|\Symfony\Component\HttpFoundation\Response
147      */
148     public function uploadDrawing(Request $request)
149     {
150         $this->validate($request, [
151             'image' => 'required|string',
152             'uploaded_to' => 'required|integer'
153         ]);
154         $this->checkPermission('image-create-all');
155         $imageBase64Data = $request->get('image');
156
157         try {
158             $uploadedTo = $request->get('uploaded_to', 0);
159             $image = $this->imageRepo->saveDrawing($imageBase64Data, $uploadedTo);
160         } catch (ImageUploadException $e) {
161             return response($e->getMessage(), 500);
162         }
163
164         return response()->json($image);
165     }
166
167     /**
168      * Get the content of an image based64 encoded.
169      * @param $id
170      * @return \Illuminate\Http\JsonResponse|mixed
171      */
172     public function getBase64Image($id)
173     {
174         $image = $this->imageRepo->getById($id);
175         $imageData = $this->imageRepo->getImageData($image);
176         if ($imageData === null) {
177             return $this->jsonError("Image data could not be found");
178         }
179         return response()->json([
180             'content' => base64_encode($imageData)
181         ]);
182     }
183
184     /**
185      * Generate a sized thumbnail for an image.
186      * @param $id
187      * @param $width
188      * @param $height
189      * @param $crop
190      * @return \Illuminate\Http\JsonResponse
191      * @throws ImageUploadException
192      * @throws \Exception
193      */
194     public function getThumbnail($id, $width, $height, $crop)
195     {
196         $this->checkPermission('image-create-all');
197         $image = $this->imageRepo->getById($id);
198         $thumbnailUrl = $this->imageRepo->getThumbnail($image, $width, $height, $crop == 'false');
199         return response()->json(['url' => $thumbnailUrl]);
200     }
201
202     /**
203      * Update image details
204      * @param integer $imageId
205      * @param Request $request
206      * @return \Illuminate\Http\JsonResponse
207      * @throws ImageUploadException
208      * @throws \Exception
209      */
210     public function update($imageId, Request $request)
211     {
212         $this->validate($request, [
213             'name' => 'required|min:2|string'
214         ]);
215         $image = $this->imageRepo->getById($imageId);
216         $this->checkOwnablePermission('image-update', $image);
217         $image = $this->imageRepo->updateImageDetails($image, $request->all());
218         return response()->json($image);
219     }
220
221     /**
222      * Show the usage of an image on pages.
223      * @param EntityRepo $entityRepo
224      * @param $id
225      * @return \Illuminate\Http\JsonResponse
226      */
227     public function usage(EntityRepo $entityRepo, $id)
228     {
229         $image = $this->imageRepo->getById($id);
230         $pageSearch = $entityRepo->searchForImage($image->url);
231         return response()->json($pageSearch);
232     }
233
234     /**
235      * Deletes an image and all thumbnail/image files
236      * @param int $id
237      * @return \Illuminate\Http\JsonResponse
238      * @throws \Exception
239      */
240     public function destroy($id)
241     {
242         $image = $this->imageRepo->getById($id);
243         $this->checkOwnablePermission('image-delete', $image);
244
245         $this->imageRepo->destroyImage($image);
246         return response()->json(trans('components.images_deleted'));
247     }
248 }