isAdmin(); } /** * Determine whether the user can view the model. */ public function view(User $user, User $model): bool { // Users can view their own profile, or admins can view any user return $user->id === $model->id || $user->isAdmin(); } /** * Determine whether the user can create models. */ public function create(User $user): bool { return $user->isAdmin(); } /** * Determine whether the user can update the model. */ public function update(User $user, User $model): bool { // Users can update their own profile, or admins can update any user return $user->id === $model->id || $user->isAdmin(); } /** * Determine whether the user can delete the model. */ public function delete(User $user, User $model): bool { // Only admins can delete users, and they cannot delete themselves return $user->isAdmin() && $user->id !== $model->id; } /** * Determine whether the user can restore the model. */ public function restore(User $user, User $model): bool { return $user->isAdmin(); } /** * Determine whether the user can permanently delete the model. */ public function forceDelete(User $user, User $model): bool { return $user->isAdmin() && $user->id !== $model->id; } /** * Determine whether the user can invite new users. */ public function invite(User $user): bool { return $user->isAdmin(); } }