$attachment->filename]); // put previous url in session if not redirect from store (not "return_to_edit"). if (Session::get('attachments.edit.fromUpdate') !== true) { Session::put('attachments.edit.url', URL::previous()); } Session::forget('attachments.edit.fromUpdate'); return view('attachments.edit', compact('attachment', 'subTitleIcon', 'subTitle')); } /** * @param Attachment $attachment * * @return \Illuminate\View\View */ public function delete(Attachment $attachment) { $subTitle = trans('firefly.delete_attachment', ['name' => $attachment->filename]); // put previous url in session Session::put('attachments.delete.url', URL::previous()); Session::flash('gaEventCategory', 'attachments'); Session::flash('gaEventAction', 'delete-attachment'); return view('attachments.delete', compact('attachment', 'subTitle')); } /** * @param AttachmentRepositoryInterface $repository * @param Attachment $attachment * * @return \Illuminate\Http\RedirectResponse */ public function destroy(AttachmentRepositoryInterface $repository, Attachment $attachment) { $name = $attachment->filename; $repository->destroy($attachment); Session::flash('success', trans('firefly.attachment_deleted', ['name' => $name])); Preferences::mark(); return redirect(Session::get('attachments.delete.url')); } /** * @param Attachment $attachment * @param AttachmentHelperInterface $helper */ public function download(Attachment $attachment, AttachmentHelperInterface $helper) { $file = $helper->getAttachmentLocation($attachment); if (file_exists($file)) { $quoted = sprintf('"%s"', addcslashes(basename($attachment->filename), '"\\')); header('Content-Description: File Transfer'); header('Content-Type: application/octet-stream'); header('Content-Disposition: attachment; filename=' . $quoted); header('Content-Transfer-Encoding: binary'); header('Connection: Keep-Alive'); header('Expires: 0'); header('Cache-Control: must-revalidate, post-check=0, pre-check=0'); header('Pragma: public'); header('Content-Length: ' . $attachment->size); echo Crypt::decrypt(file_get_contents($file)); } else { abort(404); } } /** * @param Attachment $attachment * * @return \Illuminate\Http\Response */ public function preview(Attachment $attachment) { if ($attachment->mime == 'application/pdf') { $file = public_path('images/page_white_acrobat.png'); } else { $file = public_path('images/page_green.png'); } $response = Response::make(File::get($file)); $response->header('Content-Type', 'image/png'); return $response; } /** * @param AttachmentFormRequest $request * @param AttachmentRepositoryInterface $repository * @param Attachment $attachment * * @return \Illuminate\Http\RedirectResponse */ public function update(AttachmentFormRequest $request, AttachmentRepositoryInterface $repository, Attachment $attachment) { $attachmentData = [ 'title' => $request->input('title'), 'description' => $request->input('description'), 'notes' => $request->input('notes'), ]; $repository->update($attachment, $attachmentData); Session::flash('success', 'Attachment "' . $attachment->filename . '" updated.'); Preferences::mark(); if (intval(Input::get('return_to_edit')) === 1) { // set value so edit routine will not overwrite URL: Session::put('attachments.edit.fromUpdate', true); return redirect(route('attachments.edit', [$attachment->id]))->withInput(['return_to_edit' => 1]); } // redirect to previous URL. return redirect(Session::get('attachments.edit.url')); } }