attachmentService = $attachmentService; $this->attachment = $attachment; $this->entityRepo = $entityRepo; parent::__construct(); } /** * Endpoint at which attachments are uploaded to. * @param Request $request * @return \Illuminate\Contracts\Routing\ResponseFactory|\Illuminate\Http\JsonResponse|\Symfony\Component\HttpFoundation\Response */ public function upload(Request $request) { $this->validate($request, [ 'uploaded_to' => 'required|integer|exists:pages,id', 'file' => 'required|file' ]); $pageId = $request->get('uploaded_to'); $page = $this->entityRepo->getById('page', $pageId, true); $this->checkPermission('attachment-create-all'); $this->checkOwnablePermission('page-update', $page); $uploadedFile = $request->file('file'); try { $attachment = $this->attachmentService->saveNewUpload($uploadedFile, $pageId); } catch (FileUploadException $e) { return response($e->getMessage(), 500); } return response()->json($attachment); } /** * Update an uploaded attachment. * @param Request $request * @param int $attachmentId * @return mixed * @throws \Illuminate\Validation\ValidationException */ public function uploadUpdate(Request $request, $attachmentId) { $this->validate($request, [ 'uploaded_to' => 'required|integer|exists:pages,id', 'file' => 'required|file' ]); $pageId = $request->get('uploaded_to'); $page = $this->entityRepo->getById('page', $pageId, true); $attachment = $this->attachment->findOrFail($attachmentId); $this->checkOwnablePermission('page-update', $page); $this->checkOwnablePermission('attachment-create', $attachment); if (intval($pageId) !== intval($attachment->uploaded_to)) { return $this->jsonError(trans('errors.attachment_page_mismatch')); } $uploadedFile = $request->file('file'); try { $attachment = $this->attachmentService->saveUpdatedUpload($uploadedFile, $attachment); } catch (FileUploadException $e) { return response($e->getMessage(), 500); } return response()->json($attachment); } /** * Update the details of an existing file. * @param Request $request * @param $attachmentId * @return Attachment|mixed * @throws \Illuminate\Validation\ValidationException */ public function update(Request $request, $attachmentId) { $this->validate($request, [ 'uploaded_to' => 'required|integer|exists:pages,id', 'name' => 'required|string|min:1|max:255', 'link' => 'string|min:1|max:255' ]); $pageId = $request->get('uploaded_to'); $page = $this->entityRepo->getById('page', $pageId, true); $attachment = $this->attachment->findOrFail($attachmentId); $this->checkOwnablePermission('page-update', $page); $this->checkOwnablePermission('attachment-create', $attachment); if (intval($pageId) !== intval($attachment->uploaded_to)) { return $this->jsonError(trans('errors.attachment_page_mismatch')); } $attachment = $this->attachmentService->updateFile($attachment, $request->all()); return response()->json($attachment); } /** * Attach a link to a page. * @param Request $request * @return mixed */ public function attachLink(Request $request) { $this->validate($request, [ 'uploaded_to' => 'required|integer|exists:pages,id', 'name' => 'required|string|min:1|max:255', 'link' => 'required|string|min:1|max:255' ]); $pageId = $request->get('uploaded_to'); $page = $this->entityRepo->getById('page', $pageId, true); $this->checkPermission('attachment-create-all'); $this->checkOwnablePermission('page-update', $page); $attachmentName = $request->get('name'); $link = $request->get('link'); $attachment = $this->attachmentService->saveNewFromLink($attachmentName, $link, $pageId); return response()->json($attachment); } /** * Get the attachments for a specific page. * @param $pageId * @return mixed */ public function listForPage($pageId) { $page = $this->entityRepo->getById('page', $pageId, true); $this->checkOwnablePermission('page-view', $page); return response()->json($page->attachments); } /** * Update the attachment sorting. * @param Request $request * @param $pageId * @return mixed * @throws \Illuminate\Validation\ValidationException */ public function sortForPage(Request $request, $pageId) { $this->validate($request, [ 'files' => 'required|array', 'files.*.id' => 'required|integer', ]); $page = $this->entityRepo->getById('page', $pageId); $this->checkOwnablePermission('page-update', $page); $attachments = $request->get('files'); $this->attachmentService->updateFileOrderWithinPage($attachments, $pageId); return response()->json(['message' => trans('entities.attachments_order_updated')]); } /** * Get an attachment from storage. * @param $attachmentId * @return \Illuminate\Contracts\Routing\ResponseFactory|\Illuminate\Http\RedirectResponse|\Illuminate\Routing\Redirector|\Symfony\Component\HttpFoundation\Response * @throws \Illuminate\Contracts\Filesystem\FileNotFoundException * @throws NotFoundException */ public function get($attachmentId) { $attachment = $this->attachment->findOrFail($attachmentId); $page = $this->entityRepo->getById('page', $attachment->uploaded_to); if ($page === null) { throw new NotFoundException(trans('errors.attachment_not_found')); } $this->checkOwnablePermission('page-view', $page); if ($attachment->external) { return redirect($attachment->path); } $attachmentContents = $this->attachmentService->getAttachmentFromStorage($attachment); return $this->downloadResponse($attachmentContents, $attachment->getFileName()); } /** * Delete a specific attachment in the system. * @param $attachmentId * @return mixed * @throws \Exception */ public function delete($attachmentId) { $attachment = $this->attachment->findOrFail($attachmentId); $this->checkOwnablePermission('attachment-delete', $attachment); $this->attachmentService->deleteFile($attachment); return response()->json(['message' => trans('entities.attachments_deleted')]); } }