fishdaa/laravel-resource-permissions
最新稳定版本:v0.4.1
Composer 安装命令:
composer require fishdaa/laravel-resource-permissions
包简介
Extend Spatie Laravel Permission with resource-based permissions and roles
README 文档
README
A Laravel package that extends Spatie Laravel Permission with resource-based permissions and roles. This package allows you to assign permissions and roles to users for specific resources (polymorphic relationships), while maintaining full compatibility with Spatie's existing global permission system.
Features
- Resource-based permissions: Assign permissions to users for specific resources (e.g., articles, projects, documents)
- Resource-based roles: Assign roles to users for specific resources
- Polymorphic relationships: Works with any Eloquent model as a resource
- Seamless integration: Works alongside Spatie's existing permission system
- Full Spatie compatibility: Uses Spatie's Permission and Role models directly
Installation
composer require fishdaa/laravel-resource-permissions
Publish Migrations
php artisan vendor:publish --tag=resource-permissions-migrations
Run Migrations
php artisan migrate
Publish Configuration (Optional)
php artisan vendor:publish --tag=resource-permissions-config
Quick Start
1. Add Trait to User Model
use Fishdaa\LaravelResourcePermissions\Traits\HasResourcePermissions; use Spatie\Permission\Traits\HasRoles; class User extends Authenticatable { use HasRoles; // Spatie's trait use HasResourcePermissions; // Resource permissions trait }
2. Use Resource Permissions
$user = User::find(1); $article = Article::find(1); // Give permission for a specific resource $user->givePermissionToResource('edit-article', $article); // Check permission for a resource if ($user->hasPermissionForResource('edit-article', $article)) { // User can edit this article } // Assign role for a resource $user->assignRoleToResource('article-editor', $article); // Get all permissions for a resource $permissions = $user->getPermissionsForResource($article);
Documentation
For detailed documentation, please see the docs folder.
- Installation Guide
- Configuration
- UUID Setup - Configure UUIDs instead of integer IDs
- Usage & API Reference
- Spatie Integration
- Examples
- Advanced Usage
- Troubleshooting
Requirements
- PHP >= 8.0
- Laravel >= 8.0 (supports Laravel 8, 9, 10, 11, and 12)
- Spatie Laravel Permission >= 6.0
Testing
Run the test suite using Composer:
composer test
Or run PHPUnit directly:
vendor/bin/phpunit
To run specific test suites:
# Run unit tests only vendor/bin/phpunit tests/Unit # Run feature tests only vendor/bin/phpunit tests/Feature # Run integration tests only vendor/bin/phpunit tests/Integration
Contributing
Contributions are welcome! Please feel free to submit a Pull Request. Please make sure your code follows the existing code style and includes tests for new features.
License
The MIT License (MIT). Please see https://opensource.org/licenses/MIT for more information.
统计信息
- 总下载量: 7
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 0
- 点击次数: 0
- 依赖项目数: 0
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2025-11-12