]> BookStack Code Mirror - bookstack/blob - app/Http/Controllers/Images/UserImageController.php
Started diversion to not using image manager for cover/system/user
[bookstack] / app / Http / Controllers / Images / UserImageController.php
1 <?php
2
3 namespace BookStack\Http\Controllers\Images;
4
5 // TODO - Replace this with user-controller-level handling
6 // Since won't be part of image manager handling
7
8 use BookStack\Exceptions\ImageUploadException;
9 use BookStack\Uploads\ImageRepo;
10 use Illuminate\Http\Request;
11 use BookStack\Http\Controllers\Controller;
12
13 class UserImageController extends Controller
14 {
15     protected $imageRepo;
16
17     /**
18      * UserImageController constructor.
19      * @param ImageRepo $imageRepo
20      */
21     public function __construct(ImageRepo $imageRepo)
22     {
23         $this->imageRepo = $imageRepo;
24         parent::__construct();
25     }
26
27     /**
28      * Get a list of user profile images, in a list.
29      * @param Request $request
30      * @return \Illuminate\Http\JsonResponse
31      */
32     public function list(Request $request)
33     {
34         $page = $request->get('page', 1);
35         $searchTerm = $request->get('search', null);
36         $userId = $request->get('uploaded_to', null);
37
38         $this->checkPermissionOrCurrentUser('users-manage', $userId);
39
40         $imgData = $this->imageRepo->getPaginatedByType('user', $page, 24, $userId, $searchTerm);
41         return response()->json($imgData);
42     }
43
44     /**
45      * Store a new user profile image in the system.
46      * @param Request $request
47      * @return Illuminate\Http\JsonResponse
48      * @throws \Exception
49      */
50     public function create(Request $request)
51     {
52         $this->checkPermission('image-create-all');
53
54         $this->validate($request, [
55             'uploaded_to' => 'required|integer',
56             'file' => $this->imageRepo->getImageValidationRules()
57         ]);
58
59         $userId = $request->get('uploaded_to', null);
60         $this->checkPermissionOrCurrentUser('users-manage', $userId);
61
62         try {
63             $imageUpload = $request->file('file');
64             $uploadedTo = $request->get('uploaded_to', 0);
65             $image = $this->imageRepo->saveNew($imageUpload, 'user', $uploadedTo);
66         } catch (ImageUploadException $e) {
67             return response($e->getMessage(), 500);
68         }
69
70         return response()->json($image);
71     }
72
73 }