Policy
MoonShine не отходит от концепций Laravel и также использует Laravel policy для работы с правами доступа.
В контроллерах ресурсов MoonShine каждый метод будет проверяться на наличие разрешений. Если у вас возникнут трудности, обратитесь к официальной документации Laravel.
По умолчанию проверка разрешений для ресурсов отключена.
Чтобы включить её, необходимо добавить свойство $withPolicy
.
namespace App\MoonShine\Resources; use MoonShine\Laravel\Resources\ModelResource; class PostResource extends ModelResource{ protected bool $withPolicy = true; // ...}
Доступные методы Policy:
viewAny
- страница индекса;view
- детальная страница;create
- создание записи;update
- редактирование записи;delete
- удаление записи;massDelete
- массовое удаление записей;restore
- восстановление записи после мягкого удаления;forceDelete
- окончательное удаление записи из базы данных.
namespace App\Policies; use App\Models\Post;use Illuminate\Auth\Access\HandlesAuthorization;use MoonShine\Laravel\Models\MoonshineUser; class PostPolicy{ use HandlesAuthorization; public function viewAny(MoonshineUser $user) { return true; } public function view(MoonshineUser $user, Post $model) { return true; } public function create(MoonshineUser $user) { return true; } public function update(MoonshineUser $user, Post $model) { return true; } public function delete(MoonshineUser $user, Post $model) { return true; } public function restore(MoonshineUser $user, Post $model) { return true; } public function forceDelete(MoonshineUser $user, Post $model) { return true; } public function massDelete(MoonshineUser $user) { return true; }}
Создать Policy с готовым набором методов под MoonShine можно с помощью команды moonshine:policy
.
php artisan moonshine:policy PostPolicy
После выполнения команды будет создан класс в директории app/Policies
.
Если вы используете режим $withPolicy
для системных ресурсов,
вам необходимо самостоятельно их зарегистрировать в провайдере.
По умолчанию Laravel автоматически регистрирует Policy для моделей в директории app/Models
.
Пример регистрации для системных моделей, которые не располагаются в директории app/Models
:
use App\Policies\MoonshineUserPolicy;use App\Policies\MoonshineUserRolePolicy;use MoonShine\Laravel\Models\MoonshineUserRole;use MoonShine\Laravel\Models\MoonshineUser; class AuthServiceProvider extends ServiceProvider{ public function boot(): void { Gate::policy(MoonshineUser::class, MoonshineUserPolicy::class); Gate::policy(MoonshineUserRole::class, MoonshineUserRolePolicy::class); }}
Собственная логика
Также вы можете переопределить метод isCan()
в ресурсе и реализовать собственную логику или дополнить текущую.
use MoonShine\Laravel\Enums\Ability; protected function isCan(Ability $ability): bool{ return parent::isCan($ability);}
Также рекомендуем ознакомится с разделом Авторизация.