]> git.localhorst.tv Git - alttp.git/blob - app/Policies/TournamentPolicy.php
switch SNES default port
[alttp.git] / app / Policies / TournamentPolicy.php
1 <?php
2
3 namespace App\Policies;
4
5 use App\Models\Tournament;
6 use App\Models\User;
7 use Illuminate\Auth\Access\HandlesAuthorization;
8
9 class TournamentPolicy
10 {
11         use HandlesAuthorization;
12
13         /**
14          * Determine whether the user can view any models.
15          *
16          * @param  \App\Models\User  $user
17          * @return \Illuminate\Auth\Access\Response|bool
18          */
19         public function viewAny(?User $user)
20         {
21                 return true;
22         }
23
24         /**
25          * Determine whether the user can view the model.
26          *
27          * @param  \App\Models\User  $user
28          * @param  \App\Models\Tournament  $tournament
29          * @return \Illuminate\Auth\Access\Response|bool
30          */
31         public function view(?User $user, Tournament $tournament)
32         {
33                 return true;
34         }
35
36         /**
37          * Determine whether the user can create models.
38          *
39          * @param  \App\Models\User  $user
40          * @return \Illuminate\Auth\Access\Response|bool
41          */
42         public function create(User $user)
43         {
44                 return $user->isAdmin();
45         }
46
47         /**
48          * Determine whether the user can update the model.
49          *
50          * @param  \App\Models\User  $user
51          * @param  \App\Models\Tournament  $tournament
52          * @return \Illuminate\Auth\Access\Response|bool
53          */
54         public function update(User $user, Tournament $tournament)
55         {
56                 return $user->isAdmin() || $user->isTournamentAdmin($tournament);
57         }
58
59         /**
60          * Determine whether the user can delete the model.
61          *
62          * @param  \App\Models\User  $user
63          * @param  \App\Models\Tournament  $tournament
64          * @return \Illuminate\Auth\Access\Response|bool
65          */
66         public function delete(User $user, Tournament $tournament)
67         {
68                 return false;
69         }
70
71         /**
72          * Determine whether the user can restore the model.
73          *
74          * @param  \App\Models\User  $user
75          * @param  \App\Models\Tournament  $tournament
76          * @return \Illuminate\Auth\Access\Response|bool
77          */
78         public function restore(User $user, Tournament $tournament)
79         {
80                 return false;
81         }
82
83         /**
84          * Determine whether the user can permanently delete the model.
85          *
86          * @param  \App\Models\User  $user
87          * @param  \App\Models\Tournament  $tournament
88          * @return \Illuminate\Auth\Access\Response|bool
89          */
90         public function forceDelete(User $user, Tournament $tournament)
91         {
92                 return false;
93         }
94
95         /**
96          * Determine whether the user can add rounds the model.
97          *
98          * @param  \App\Models\User  $user
99          * @param  \App\Models\Tournament  $tournament
100          * @return \Illuminate\Auth\Access\Response|bool
101          */
102         public function addRound(User $user, Tournament $tournament)
103         {
104                 return !$tournament->locked && ($user->isRunner($tournament) || $user->isTournamentAdmin($tournament));
105         }
106
107         /**
108          * Determine whether the user can apply to participate.
109          *
110          * @param  \App\Models\User  $user
111          * @param  \App\Models\Tournament  $tournament
112          * @return \Illuminate\Auth\Access\Response|bool
113          */
114         public function apply(User $user, Tournament $tournament)
115         {
116                 return $tournament->accept_applications && !$user->isRunner($tournament) && !$user->isApplicant($tournament);
117         }
118
119         /**
120          * Determine whether the user can view the tournament protocol.
121          *
122          * @param  \App\Models\User  $user
123          * @param  \App\Models\Tournament  $tournament
124          * @return \Illuminate\Auth\Access\Response|bool
125          */
126         public function viewProtocol(User $user, Tournament $tournament)
127         {
128                 return $user->isTournamentCrew($tournament);
129         }
130
131 }