use BookStack\Entities\Models\Chapter;
use BookStack\Entities\Models\Entity;
use BookStack\Entities\Queries\BookQueries;
+use BookStack\Entities\Queries\PageQueries;
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;
public function __construct(
protected BookRepo $bookRepo,
protected BookQueries $queries,
+ protected PageQueries $pageQueries,
) {
}
{
$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);
->withType()
->withField('pages', function (Entity $entity) {
if ($entity instanceof Chapter) {
- return (new ApiEntityListFormatter($entity->pages->all()))->format();
+ $pages = $this->pageQueries->visibleForChapterList($entity->id)->get()->all();
+ return (new ApiEntityListFormatter($pages))->format();
}
return null;
})->format();
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);