BookStack/app/Entities/Repos/BookRepo.php

135 lines
3.4 KiB
PHP
Raw Normal View History

2021-06-26 17:23:15 +02:00
<?php
namespace BookStack\Entities\Repos;
2019-09-16 00:28:23 +02:00
use BookStack\Actions\ActivityType;
use BookStack\Actions\TagRepo;
use BookStack\Entities\Models\Book;
use BookStack\Entities\Tools\TrashCan;
use BookStack\Exceptions\ImageUploadException;
2019-09-16 00:28:23 +02:00
use BookStack\Exceptions\NotFoundException;
use BookStack\Facades\Activity;
use BookStack\Uploads\ImageRepo;
use Exception;
use Illuminate\Contracts\Pagination\LengthAwarePaginator;
use Illuminate\Http\UploadedFile;
use Illuminate\Support\Collection;
2019-09-16 00:28:23 +02:00
class BookRepo
2019-09-16 00:28:23 +02:00
{
protected $baseRepo;
protected $tagRepo;
protected $imageRepo;
/**
* BookRepo constructor.
*/
public function __construct(BaseRepo $baseRepo, TagRepo $tagRepo, ImageRepo $imageRepo)
{
$this->baseRepo = $baseRepo;
$this->tagRepo = $tagRepo;
$this->imageRepo = $imageRepo;
}
/**
* Get all books in a paginated format.
*/
public function getAllPaginated(int $count = 20, string $sort = 'name', string $order = 'asc'): LengthAwarePaginator
{
return Book::visible()->with('cover')->orderBy($sort, $order)->paginate($count);
}
/**
* Get the books that were most recently viewed by this user.
*/
public function getRecentlyViewed(int $count = 20): Collection
{
return Book::visible()->withLastView()
->having('last_viewed_at', '>', 0)
->orderBy('last_viewed_at', 'desc')
->take($count)->get();
}
/**
* Get the most popular books in the system.
*/
public function getPopular(int $count = 20): Collection
{
return Book::visible()->withViewCount()
->having('view_count', '>', 0)
->orderBy('view_count', 'desc')
->take($count)->get();
}
/**
* Get the most recently created books from the system.
*/
public function getRecentlyCreated(int $count = 20): Collection
{
return Book::visible()->orderBy('created_at', 'desc')
->take($count)->get();
}
2019-09-16 00:28:23 +02:00
/**
* Get a book by its slug.
2019-09-16 00:28:23 +02:00
*/
public function getBySlug(string $slug): Book
{
$book = Book::visible()->where('slug', '=', $slug)->first();
if ($book === null) {
throw new NotFoundException(trans('errors.book_not_found'));
}
2019-09-16 00:28:23 +02:00
return $book;
}
/**
2021-06-26 17:23:15 +02:00
* Create a new book in the system.
2019-09-16 00:28:23 +02:00
*/
public function create(array $input): Book
2019-09-16 00:28:23 +02:00
{
$book = new Book();
$this->baseRepo->create($book, $input);
2020-11-08 00:15:13 +01:00
Activity::addForEntity($book, ActivityType::BOOK_CREATE);
2021-06-26 17:23:15 +02:00
return $book;
}
2019-09-16 00:28:23 +02:00
/**
* Update the given book.
*/
public function update(Book $book, array $input): Book
{
$this->baseRepo->update($book, $input);
2020-11-08 00:15:13 +01:00
Activity::addForEntity($book, ActivityType::BOOK_UPDATE);
2021-06-26 17:23:15 +02:00
return $book;
}
2019-09-16 00:28:23 +02:00
/**
* Update the given book's cover image, or clear it.
2021-06-26 17:23:15 +02:00
*
* @throws ImageUploadException
* @throws Exception
*/
public function updateCoverImage(Book $book, ?UploadedFile $coverImage, bool $removeImage = false)
{
$this->baseRepo->updateCoverImage($book, $coverImage, $removeImage);
2019-09-16 00:28:23 +02:00
}
/**
* Remove a book from the system.
2021-06-26 17:23:15 +02:00
*
* @throws Exception
*/
public function destroy(Book $book)
{
$trashCan = new TrashCan();
$trashCan->softDestroyBook($book);
2020-11-08 00:15:13 +01:00
Activity::addForEntity($book, ActivityType::BOOK_DELETE);
$trashCan->autoClearOld();
}
}