use BookStack\Entities\Repos\BookRepo;
use BookStack\Entities\Tools\BookContents;
use BookStack\Http\ApiController;
+use BookStack\Permissions\Permission;
use Illuminate\Http\Request;
use Illuminate\Validation\ValidationException;
{
$books = $this->queries
->visibleForList()
+ ->with(['cover:id,name,url'])
->addSelect(['created_by', 'updated_by']);
return $this->apiListingResponse($books, [
*/
public function create(Request $request)
{
- $this->checkPermission('book-create-all');
+ $this->checkPermission(Permission::BookCreateAll);
$requestData = $this->validate($request, $this->rules()['create']);
$book = $this->bookRepo->create($requestData);
public function update(Request $request, string $id)
{
$book = $this->queries->findVisibleByIdOrFail(intval($id));
- $this->checkOwnablePermission('book-update', $book);
+ $this->checkOwnablePermission(Permission::BookUpdate, $book);
$requestData = $this->validate($request, $this->rules()['update']);
$book = $this->bookRepo->update($book, $requestData);
public function delete(string $id)
{
$book = $this->queries->findVisibleByIdOrFail(intval($id));
- $this->checkOwnablePermission('book-delete', $book);
+ $this->checkOwnablePermission(Permission::BookDelete, $book);
$this->bookRepo->destroy($book);