X-Git-Url: http://source.bookstackapp.com/bookstack/blobdiff_plain/3c7bd297ea9718a4185beebe68bcb8a93f5b2740..1b29d44689bbcf40fc79ef9b4257fc387d4b64be:/app/Http/Controllers/BookController.php diff --git a/app/Http/Controllers/BookController.php b/app/Http/Controllers/BookController.php index 41d8bed26..91cd4bd51 100644 --- a/app/Http/Controllers/BookController.php +++ b/app/Http/Controllers/BookController.php @@ -2,8 +2,10 @@ namespace Oxbow\Http\Controllers; +use Activity; use Illuminate\Http\Request; +use Illuminate\Support\Facades\Auth; use Illuminate\Support\Str; use Oxbow\Http\Requests; use Oxbow\Repos\BookRepo; @@ -24,6 +26,7 @@ class BookController extends Controller { $this->bookRepo = $bookRepo; $this->pageRepo = $pageRepo; + parent::__construct(); } /** @@ -44,28 +47,29 @@ class BookController extends Controller */ public function create() { + $this->checkPermission('book-create'); return view('books/create'); } /** * Store a newly created book in storage. * - * @param Request $request + * @param Request $request * @return Response */ public function store(Request $request) { + $this->checkPermission('book-create'); $this->validate($request, [ - 'name' => 'required|string|max:255', + 'name' => 'required|string|max:255', 'description' => 'string|max:1000' ]); $book = $this->bookRepo->newFromInput($request->all()); - $slug = Str::slug($book->name); - while($this->bookRepo->countBySlug($slug) > 0) { - $slug .= '1'; - } - $book->slug = $slug; + $book->slug = $this->bookRepo->findSuitableSlug($book->name); + $book->created_by = Auth::user()->id; + $book->updated_by = Auth::user()->id; $book->save(); + Activity::add($book, 'book_create', $book->id); return redirect('/books'); } @@ -78,7 +82,7 @@ class BookController extends Controller public function show($slug) { $book = $this->bookRepo->getBySlug($slug); - return view('books/show', ['book' => $book]); + return view('books/show', ['book' => $book, 'current' => $book]); } /** @@ -89,42 +93,58 @@ class BookController extends Controller */ public function edit($slug) { + $this->checkPermission('book-update'); $book = $this->bookRepo->getBySlug($slug); - return view('books/edit', ['book' => $book]); + return view('books/edit', ['book' => $book, 'current' => $book]); } /** * Update the specified book in storage. * * @param Request $request - * @param $slug + * @param $slug * @return Response */ public function update(Request $request, $slug) { + $this->checkPermission('book-update'); $book = $this->bookRepo->getBySlug($slug); $this->validate($request, [ - 'name' => 'required|string|max:255', + 'name' => 'required|string|max:255', 'description' => 'string|max:1000' ]); - $slug = Str::slug($book->name); - while($this->bookRepo->countBySlug($slug) > 0 && $book->slug != $slug) { - $slug += '1'; - } - $book->slug = $slug; + $book->fill($request->all()); + $book->slug = $this->bookRepo->findSuitableSlug($book->name, $book->id); + $book->updated_by = Auth::user()->id; $book->save(); - return redirect('/books'); + Activity::add($book, 'book_update', $book->id); + return redirect($book->getUrl()); + } + + /** + * Shows the page to confirm deletion + * @param $bookSlug + * @return \Illuminate\View\View + */ + public function showDelete($bookSlug) + { + $this->checkPermission('book-delete'); + $book = $this->bookRepo->getBySlug($bookSlug); + return view('books/delete', ['book' => $book, 'current' => $book]); } /** * Remove the specified book from storage. * - * @param int $id + * @param $bookSlug * @return Response */ - public function destroy($id) + public function destroy($bookSlug) { - $this->bookRepo->destroyById($id); + $this->checkPermission('book-delete'); + $book = $this->bookRepo->getBySlug($bookSlug); + Activity::addMessage('book_delete', 0, $book->name); + $this->bookRepo->destroyBySlug($bookSlug); return redirect('/books'); } }