2019-10-05 13:55:01 +02:00
|
|
|
<?php namespace BookStack\Entities\Repos;
|
|
|
|
|
2020-11-07 23:37:27 +01:00
|
|
|
use BookStack\Actions\ActivityType;
|
2020-11-22 01:17:45 +01:00
|
|
|
use BookStack\Entities\Models\Book;
|
|
|
|
use BookStack\Entities\Models\Chapter;
|
2020-11-22 00:20:54 +01:00
|
|
|
use BookStack\Entities\Tools\BookContents;
|
|
|
|
use BookStack\Entities\Tools\TrashCan;
|
2019-10-05 13:55:01 +02:00
|
|
|
use BookStack\Exceptions\MoveOperationException;
|
|
|
|
use BookStack\Exceptions\NotFoundException;
|
2020-11-07 23:37:27 +01:00
|
|
|
use BookStack\Facades\Activity;
|
2019-10-05 13:55:01 +02:00
|
|
|
use Exception;
|
|
|
|
use Illuminate\Support\Collection;
|
|
|
|
|
|
|
|
class ChapterRepo
|
|
|
|
{
|
|
|
|
|
|
|
|
protected $baseRepo;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* ChapterRepo constructor.
|
|
|
|
*/
|
|
|
|
public function __construct(BaseRepo $baseRepo)
|
|
|
|
{
|
|
|
|
$this->baseRepo = $baseRepo;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get a chapter via the slug.
|
|
|
|
* @throws NotFoundException
|
|
|
|
*/
|
|
|
|
public function getBySlug(string $bookSlug, string $chapterSlug): Chapter
|
|
|
|
{
|
|
|
|
$chapter = Chapter::visible()->whereSlugs($bookSlug, $chapterSlug)->first();
|
|
|
|
|
|
|
|
if ($chapter === null) {
|
|
|
|
throw new NotFoundException(trans('errors.chapter_not_found'));
|
|
|
|
}
|
|
|
|
|
|
|
|
return $chapter;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Create a new chapter in the system.
|
|
|
|
*/
|
|
|
|
public function create(array $input, Book $parentBook): Chapter
|
|
|
|
{
|
|
|
|
$chapter = new Chapter();
|
|
|
|
$chapter->book_id = $parentBook->id;
|
|
|
|
$chapter->priority = (new BookContents($parentBook))->getLastPriority() + 1;
|
|
|
|
$this->baseRepo->create($chapter, $input);
|
2020-11-08 00:15:13 +01:00
|
|
|
Activity::addForEntity($chapter, ActivityType::CHAPTER_CREATE);
|
2019-10-05 13:55:01 +02:00
|
|
|
return $chapter;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Update the given chapter.
|
|
|
|
*/
|
|
|
|
public function update(Chapter $chapter, array $input): Chapter
|
|
|
|
{
|
|
|
|
$this->baseRepo->update($chapter, $input);
|
2020-11-08 00:15:13 +01:00
|
|
|
Activity::addForEntity($chapter, ActivityType::CHAPTER_UPDATE);
|
2019-10-05 13:55:01 +02:00
|
|
|
return $chapter;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Update the permissions of a chapter.
|
|
|
|
*/
|
|
|
|
public function updatePermissions(Chapter $chapter, bool $restricted, Collection $permissions = null)
|
|
|
|
{
|
|
|
|
$this->baseRepo->updatePermissions($chapter, $restricted, $permissions);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Remove a chapter from the system.
|
|
|
|
* @throws Exception
|
|
|
|
*/
|
|
|
|
public function destroy(Chapter $chapter)
|
|
|
|
{
|
|
|
|
$trashCan = new TrashCan();
|
2020-09-28 00:24:33 +02:00
|
|
|
$trashCan->softDestroyChapter($chapter);
|
2020-11-08 00:15:13 +01:00
|
|
|
Activity::addForEntity($chapter, ActivityType::CHAPTER_DELETE);
|
2020-11-07 14:58:23 +01:00
|
|
|
$trashCan->autoClearOld();
|
2019-10-05 13:55:01 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Move the given chapter into a new parent book.
|
|
|
|
* The $parentIdentifier must be a string of the following format:
|
|
|
|
* 'book:<id>' (book:5)
|
|
|
|
* @throws MoveOperationException
|
|
|
|
*/
|
|
|
|
public function move(Chapter $chapter, string $parentIdentifier): Book
|
|
|
|
{
|
|
|
|
$stringExploded = explode(':', $parentIdentifier);
|
|
|
|
$entityType = $stringExploded[0];
|
|
|
|
$entityId = intval($stringExploded[1]);
|
|
|
|
|
|
|
|
if ($entityType !== 'book') {
|
|
|
|
throw new MoveOperationException('Chapters can only be moved into books');
|
|
|
|
}
|
|
|
|
|
2020-11-07 23:37:27 +01:00
|
|
|
/** @var Book $parent */
|
2019-10-05 13:55:01 +02:00
|
|
|
$parent = Book::visible()->where('id', '=', $entityId)->first();
|
|
|
|
if ($parent === null) {
|
|
|
|
throw new MoveOperationException('Book to move chapter into not found');
|
|
|
|
}
|
|
|
|
|
|
|
|
$chapter->changeBook($parent->id);
|
|
|
|
$chapter->rebuildPermissions();
|
2020-11-08 00:15:13 +01:00
|
|
|
Activity::addForEntity($chapter, ActivityType::CHAPTER_MOVE);
|
2020-11-07 23:37:27 +01:00
|
|
|
|
2019-10-05 13:55:01 +02:00
|
|
|
return $parent;
|
|
|
|
}
|
|
|
|
}
|