2025-08-07 18:46:34 +01:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace App\Policies;
|
|
|
|
|
|
|
|
use App\Invitation;
|
|
|
|
use App\User;
|
|
|
|
use Illuminate\Auth\Access\HandlesAuthorization;
|
|
|
|
use Illuminate\Auth\Access\Response;
|
|
|
|
|
|
|
|
class InvitationPolicy
|
|
|
|
{
|
|
|
|
use HandlesAuthorization;
|
|
|
|
|
2025-08-07 21:52:07 +01:00
|
|
|
public function viewAny(User $user): Response
|
2025-08-07 18:46:34 +01:00
|
|
|
{
|
2025-08-07 21:52:07 +01:00
|
|
|
return $user->can('admin.manageInvitations') ? Response::allow() : Response::deny(__('You do not have permission to view invitation requests.'));
|
2025-08-07 18:46:34 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
public function create(?User $user): Response
|
|
|
|
{
|
|
|
|
if (is_null($user)) {
|
|
|
|
return Response::allow();
|
|
|
|
}
|
|
|
|
|
2025-08-07 21:52:07 +01:00
|
|
|
return $user->can('admin.manageInvitations') ? Response::allow() : Response::deny(__('You do not have permission to request privileged invitations.'));
|
2025-08-07 18:46:34 +01:00
|
|
|
}
|
|
|
|
|
2025-08-07 21:52:07 +01:00
|
|
|
public function update(User $user, Invitation $invitation): Response
|
2025-08-07 18:46:34 +01:00
|
|
|
{
|
2025-08-07 21:52:07 +01:00
|
|
|
return $user->can('admin.manageInvitations') ? Response::allow() : Response::deny(__('You do not have permission to update invitations.'));
|
2025-08-07 18:46:34 +01:00
|
|
|
}
|
2025-08-07 21:52:07 +01:00
|
|
|
|
|
|
|
// no delete policy; cleanup is handled by jobs, no users can delete directly
|
2025-08-07 18:46:34 +01:00
|
|
|
}
|