Package Data | |
---|---|
Maintainer Username: | arstoykov |
Maintainer Contact: | me@astoykov.com (Antoan Stoykov) |
Package Create Date: | 2017-10-27 |
Package Last Update: | 2019-09-27 |
Home Page: | |
Language: | PHP |
License: | MIT |
Last Refreshed: | 2025-01-14 15:11:13 |
Package Statistics | |
---|---|
Total Downloads: | 591 |
Monthly Downloads: | 0 |
Daily Downloads: | 0 |
Total Stars: | 0 |
Total Watchers: | 2 |
Total Forks: | 1 |
Total Open Issues: | 0 |
Ohrana is a granular role-and-rule-based access control list. What does 'granular' mean? It means that you can give a role permissions for a specific method in a specific controller in a specific namespace, or you can give a role access to a whole namespace, or you can give a role global access, all that without changing a single line in your code.
Permissions are rule-based and are bound to roles, which means that every role has it's own set of permissions, unlike traditional ACL libraries where you have general permissions such as 'Edit Post' which can be attached to multiple roles. Rules are simple strings with delimiters that describe the access that that permission grants.
App\Http\Controllers\ExampleController@example
grants access to the example method of ExampleController.
App\Http\Controllers\ExampleController@example;test;foo
grants access to the example, test, foo methods of ExampleController.
App\Http\Controllers\ExampleController@All
grants access to all methods in ExampleController.
App\Http\Controllers\
grants access to all controllers in the App\Http\Controllers\ namespace.
All
grants global access.
This model of ACL is very flexible and granular. You can say that Junior Staff members can access BlogController@view
and BlogController@edit
, but not BlogController@delete
until they have 20 days of service.
As already mentioned this model is very granular and requires a lot of managing if you want to use it's full capabilities.
composer require stoykov/ohrana
stoykov\Ohrana\OhranaServiceProvider.php
in your bootstrap/app.php
filebootstrap/app.php
class_alias('stoykov\Ohrana\Facades\Ohrana', 'Ohrana');
In order to protect a route you need to register the OhranaMiddleware
in your app and add it to your routes.
stoykov\Ohrana\Traits\OhranaRole
trait needs to be added to your user model. This adds the hasPermission
method which checks whether this user has access to the resource requested.
You can have your own Role and Permission models. All you need to do is write your own repositories implementing stoykov\Ohrana\Repositories\Role
and stoykov\Ohrana\Repositories\Permission
interfaces respectfully and change the two namespaces in the configuration file.
Ohrana scans paths for controllers, when it finds a controller it gets all it's methods and caches them. By default only the app/Http/Controllers/*
path is scanned for controllers, but you can add more paths in the configuration file. To list all available Namespaces/Controllers/Methods call the Ohrana::all()
method from the Ohrana facade. Or you can always write your rules by hand.