X-Git-Url: http://source.bookstackapp.com/bookstack/blobdiff_plain/fd1a0dceb25b9b2a2707df754e9ff56b96de34b6..1b29d44689bbcf40fc79ef9b4257fc387d4b64be:/app/Http/Controllers/BookController.php diff --git a/app/Http/Controllers/BookController.php b/app/Http/Controllers/BookController.php index 269e240a4..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,31 +93,31 @@ 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' ]); $book->fill($request->all()); - $slug = Str::slug($book->name); - while($this->bookRepo->countBySlug($slug) > 0 && $book->slug != $slug) { - $slug += '1'; - } - $book->slug = $slug; + $book->slug = $this->bookRepo->findSuitableSlug($book->name, $book->id); + $book->updated_by = Auth::user()->id; $book->save(); + Activity::add($book, 'book_update', $book->id); return redirect($book->getUrl()); } @@ -124,8 +128,9 @@ class BookController extends Controller */ public function showDelete($bookSlug) { + $this->checkPermission('book-delete'); $book = $this->bookRepo->getBySlug($bookSlug); - return view('books/delete', ['book' => $book]); + return view('books/delete', ['book' => $book, 'current' => $book]); } /** @@ -136,6 +141,9 @@ class BookController extends Controller */ public function destroy($bookSlug) { + $this->checkPermission('book-delete'); + $book = $this->bookRepo->getBySlug($bookSlug); + Activity::addMessage('book_delete', 0, $book->name); $this->bookRepo->destroyBySlug($bookSlug); return redirect('/books'); }