relaxsd / laravel-model-gates
Model gates for Laravel
Installs: 15
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 1
Forks: 0
Open Issues: 0
pkg:composer/relaxsd/laravel-model-gates
Requires
- php: >=5.4.0
- illuminate/support: ~5.0|~6.0|~7.0|~8.0|^9.0|^10.0|^11.0|^12.0
Requires (Dev)
- mockery/mockery: ~0.9|^1.6
- phpspec/phpspec: ~2.0|^7.5
This package is auto-updated.
Last update: 2025-10-20 21:24:43 UTC
README
This packages allows authorized access to model attributes, so by using the Laravel Gates and Policies, you can reduce the data returned based on authorization.
Install
Pull this package in through Composer.
{ "require": { "relaxsd/laravel-model-gates": "0.1.*" } }
Usage
Here's an example of a model gate.
use Relaxsd\Gate\ModelGate; class ProjectGate extends ModelGate { public function members() { if (\Gate::allows('indexForProject', [\App\Member::class, $this->entity])) { return $this->entity->members; } return new \Illuminate\Database\Eloquent\Collection(); // Not authorized: return an empty collection instead. } }
Next, on your entity, pull in the Relaxsd\Gate\ModelGateTrait trait, which will automatically instantiate your model gate class.
Here's an example - maybe a Laravel User model.
<?php use Relaxsd\Gate\ModelGateTrait; class Project extends \Eloquent { use ModelGateTrait; protected $gate = 'ProjectGate'; }
That's it! You're done. Now, within your code, you can do:
return $project->gate()->members; // Only the members we're allowed to see
Notice how the call to the gate() method (which will return your new or cached model gate object) also provides the benefit of making it perfectly clear where you must go, should you need to modify the implementation.
Have fun!