authentikate/app/Policies/UserPolicy.php
Javier Feliz f7ee4baa61
Some checks failed
linter / quality (push) Successful in 3m5s
tests / ci (push) Has been cancelled
admin user policies
2025-08-01 22:29:35 -04:00

75 lines
1.7 KiB
PHP

<?php
namespace App\Policies;
use App\Models\User;
class UserPolicy
{
/**
* Determine whether the user can view any models.
*/
public function viewAny(User $user): bool
{
return $user->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();
}
}