]> BookStack Code Mirror - bookstack/blob - app/Entities/Repos/BookshelfRepo.php
Perms: Fixed some issues made when adding transactions
[bookstack] / app / Entities / Repos / BookshelfRepo.php
1 <?php
2
3 namespace BookStack\Entities\Repos;
4
5 use BookStack\Activity\ActivityType;
6 use BookStack\Entities\Models\Bookshelf;
7 use BookStack\Entities\Queries\BookQueries;
8 use BookStack\Entities\Tools\TrashCan;
9 use BookStack\Facades\Activity;
10 use BookStack\Util\DatabaseTransaction;
11 use Exception;
12
13 class BookshelfRepo
14 {
15     public function __construct(
16         protected BaseRepo $baseRepo,
17         protected BookQueries $bookQueries,
18         protected TrashCan $trashCan,
19     ) {
20     }
21
22     /**
23      * Create a new shelf in the system.
24      */
25     public function create(array $input, array $bookIds): Bookshelf
26     {
27         return (new DatabaseTransaction(function () use ($input, $bookIds) {
28             $shelf = new Bookshelf();
29             $this->baseRepo->create($shelf, $input);
30             $this->baseRepo->updateCoverImage($shelf, $input['image'] ?? null);
31             $this->updateBooks($shelf, $bookIds);
32             Activity::add(ActivityType::BOOKSHELF_CREATE, $shelf);
33             return $shelf;
34         }))->run();
35     }
36
37     /**
38      * Update an existing shelf in the system using the given input.
39      */
40     public function update(Bookshelf $shelf, array $input, ?array $bookIds): Bookshelf
41     {
42         $this->baseRepo->update($shelf, $input);
43
44         if (!is_null($bookIds)) {
45             $this->updateBooks($shelf, $bookIds);
46         }
47
48         if (array_key_exists('image', $input)) {
49             $this->baseRepo->updateCoverImage($shelf, $input['image'], $input['image'] === null);
50         }
51
52         Activity::add(ActivityType::BOOKSHELF_UPDATE, $shelf);
53
54         return $shelf;
55     }
56
57     /**
58      * Update which books are assigned to this shelf by syncing the given book ids.
59      * Function ensures the books are visible to the current user and existing.
60      */
61     protected function updateBooks(Bookshelf $shelf, array $bookIds)
62     {
63         $numericIDs = collect($bookIds)->map(function ($id) {
64             return intval($id);
65         });
66
67         $syncData = $this->bookQueries->visibleForList()
68             ->whereIn('id', $bookIds)
69             ->pluck('id')
70             ->mapWithKeys(function ($bookId) use ($numericIDs) {
71                 return [$bookId => ['order' => $numericIDs->search($bookId)]];
72             });
73
74         $shelf->books()->sync($syncData);
75     }
76
77     /**
78      * Remove a bookshelf from the system.
79      *
80      * @throws Exception
81      */
82     public function destroy(Bookshelf $shelf)
83     {
84         $this->trashCan->softDestroyShelf($shelf);
85         Activity::add(ActivityType::BOOKSHELF_DELETE, $shelf);
86         $this->trashCan->autoClearOld();
87     }
88 }