kesoji / laravel-removable-global-scopes
Dynamically remove global scopes from Eloquent models in Laravel
Requires
- php: ^8.1
- illuminate/database: ^10.0|^11.0|^12.0
- illuminate/support: ^10.0|^11.0|^12.0
Requires (Dev)
- orchestra/testbench: ^8.0|^9.0
- phpunit/phpunit: ^10.0|^11.0
This package is auto-updated.
Last update: 2025-05-28 05:02:07 UTC
README
A Laravel package that adds the ability to dynamically remove global scopes from Eloquent models.
Installation
You can install the package via composer:
composer require kesoji/laravel-removable-global-scopes
Usage
Add the RemovableGlobalScopes
trait to your Eloquent model:
use Illuminate\Database\Eloquent\Model; use Kesoji\RemovableGlobalScopes\RemovableGlobalScopes; class User extends Model { use RemovableGlobalScopes; // Your model code... }
Removing a Single Global Scope
You can remove a global scope by its name, class, or instance:
// Remove by name User::removeGlobalScope('active'); // Remove by class User::removeGlobalScope(ActiveScope::class); // Remove by instance User::removeGlobalScope(new ActiveScope);
Removing Multiple Global Scopes
Remove multiple global scopes at once:
User::removeGlobalScopes(['active', 'verified', TenantScope::class]);
Important Notes
⚠️ Warning: The removeGlobalScope()
and removeGlobalScopes()
methods permanently remove global scopes from the model class. This affects all subsequent queries on that model.
If you need to temporarily remove a global scope for a specific query, use Laravel's built-in withoutGlobalScope()
method instead:
// Temporary removal for a single query User::withoutGlobalScope('active')->get(); // Temporary removal of multiple scopes User::withoutGlobalScopes(['active', 'verified'])->get();
Return Value
The removeGlobalScope()
method returns the original global scopes array before removal, allowing you to potentially restore them later using Laravel's addGlobalScope()
method:
// Remove and store original scopes $originalScopes = User::removeGlobalScope('active'); // Do something without the scope... // Restore if needed if (isset($originalScopes[User::class]['active'])) { User::addGlobalScope('active', $originalScopes[User::class]['active']); }
Testing
composer test
License
The MIT License (MIT). Please see License File for more information.