fishdaa/laravel-resource-permissions

Extend Spatie Laravel Permission with resource-based permissions and roles

Maintainers

Package info

github.com/fishdaa/laravel-resource-permissions

pkg:composer/fishdaa/laravel-resource-permissions

Statistics

Installs: 8

Dependents: 0

Suggesters: 0

Stars: 0

Open Issues: 0

v0.4.1 2026-01-06 03:44 UTC

This package is auto-updated.

Last update: 2026-03-06 05:21:10 UTC


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.

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.