1 | <?php |
||
2 | |||
0 ignored issues
–
show
Coding Style
introduced
by
![]() |
|||
3 | namespace BristolSU\ControlDB\Repositories; |
||
4 | |||
5 | use BristolSU\ControlDB\Contracts\Models\Group as GroupModel; |
||
6 | use BristolSU\ControlDB\Contracts\Repositories\Group as GroupContract; |
||
7 | use Illuminate\Support\Collection; |
||
8 | |||
9 | /** |
||
10 | * Handles groups |
||
11 | */ |
||
0 ignored issues
–
show
|
|||
12 | class Group implements GroupContract |
||
13 | { |
||
14 | |||
15 | /** |
||
16 | * Get a group by ID |
||
17 | * |
||
18 | * @param int $id ID of the group |
||
19 | * @return GroupModel |
||
0 ignored issues
–
show
|
|||
20 | */ |
||
21 | 31 | public function getById(int $id): GroupModel |
|
22 | { |
||
23 | 31 | return \BristolSU\ControlDB\Models\Group::findOrFail($id); |
|
24 | } |
||
25 | |||
26 | /** |
||
27 | * Get all groups |
||
28 | * |
||
29 | * @return Collection|GroupModel[] |
||
30 | */ |
||
31 | 2 | public function all(): Collection |
|
32 | { |
||
33 | 2 | return \BristolSU\ControlDB\Models\Group::all(); |
|
34 | } |
||
35 | |||
36 | /** |
||
37 | * Create a new group |
||
38 | * |
||
39 | * @param int $dataProviderId |
||
0 ignored issues
–
show
|
|||
40 | * @return GroupModel |
||
0 ignored issues
–
show
|
|||
41 | */ |
||
42 | 4 | public function create(int $dataProviderId): GroupModel |
|
43 | { |
||
44 | 4 | return \BristolSU\ControlDB\Models\Group::create([ |
|
0 ignored issues
–
show
|
|||
45 | 4 | 'data_provider_id' => $dataProviderId |
|
46 | ]); |
||
0 ignored issues
–
show
For multi-line function calls, the closing parenthesis should be on a new line.
If a function call spawns multiple lines, the coding standard suggests to move the closing parenthesis to a new line: someFunctionCall(
$firstArgument,
$secondArgument,
$thirdArgument
); // Closing parenthesis on a new line.
![]() |
|||
47 | } |
||
48 | |||
49 | /** |
||
50 | * Delete a group by ID |
||
51 | * |
||
52 | * @param int $id |
||
0 ignored issues
–
show
|
|||
53 | */ |
||
0 ignored issues
–
show
|
|||
54 | 2 | public function delete(int $id): void |
|
55 | { |
||
56 | 2 | \BristolSU\ControlDB\Models\Group::findOrFail($id)->delete(); |
|
57 | 2 | } |
|
58 | |||
59 | /** |
||
60 | * Get a group by its data provider ID |
||
61 | * |
||
62 | * @param int $dataProviderId |
||
0 ignored issues
–
show
|
|||
63 | * @return GroupModel |
||
0 ignored issues
–
show
|
|||
64 | */ |
||
65 | 4 | public function getByDataProviderId(int $dataProviderId): GroupModel { |
|
0 ignored issues
–
show
|
|||
66 | 4 | return \BristolSU\ControlDB\Models\Group::where('data_provider_id', $dataProviderId)->firstOrFail(); |
|
67 | } |
||
68 | |||
69 | /** |
||
70 | * Paginate through all the groups |
||
71 | * |
||
72 | * @param int $page The page number to return |
||
0 ignored issues
–
show
|
|||
73 | * @param int $perPage The number of results to return per page |
||
74 | * |
||
75 | * @return Collection|GroupModel[] |
||
76 | */ |
||
77 | 3 | public function paginate(int $page, int $perPage): Collection |
|
78 | { |
||
79 | 3 | return \BristolSU\ControlDB\Models\Group::paginate($perPage, ['*'], 'page', $page)->getCollection(); |
|
80 | } |
||
81 | |||
82 | /** |
||
83 | * Get the number of groups |
||
84 | * |
||
85 | * @return int |
||
86 | */ |
||
87 | 3 | public function count(): int |
|
88 | { |
||
89 | 3 | return \BristolSU\ControlDB\Models\Group::count(); |
|
0 ignored issues
–
show
|
|||
90 | } |
||
91 | |||
92 | /** |
||
93 | * Update the group model |
||
94 | * |
||
95 | * @param int $id |
||
0 ignored issues
–
show
|
|||
96 | * @param int $dataProviderId New data provider ID |
||
97 | * @return GroupModel |
||
0 ignored issues
–
show
|
|||
98 | */ |
||
99 | 3 | public function update(int $id, int $dataProviderId): GroupModel |
|
100 | { |
||
101 | 3 | $group = $this->getById($id)->fill(['data_provider_id' => $dataProviderId]); |
|
102 | 3 | $group->save(); |
|
103 | 3 | return $group; |
|
104 | } |
||
105 | } |
||
106 |