YesAuthority is flexible authorization system for Laravel, It checks the route
permission to access a certain portion of the site or application. To add Permissions User-based
, Role-based
, Conditionally
. It uses authority.checkpost
middleware for filter permission of current accessing route, Under this middleware checked every permission of the user login.
Require this package in your composer.json
or install it by running:
composer require livelyworks/laravel-yes-authority
Now, insert into your config/app.php
.
"provider" => [
LivelyWorks\YesAuthority\YesAuthorityServiceProvider::class
];
Now, run this command after that config/yes-authority.php
and app/Http/Middleware/YesAuthorityCheckpostMiddleware.php
files are publish.
php artisan vendor:publish --tag="yesauthority"
Now, insert into your app/Http/Kernel.php
.
protected $routeMiddleware = [
'authority.checkpost' => \App\Http\Middleware\YesAuthorityCheckpostMiddleware::class
];
Use authority.checkpost
middleware for handle permission base routes.
Route::group(['middleware' => 'authority.checkpost'], function () {
// Place all those routes here which needs authentication and authorization.
});
Now, the basic setup is ready you need to configure rules of permissions using config/yes-authority
.
The structure of permissions given below, but it's highly recommended to read more on docs`.
[
'allow' => ['*'], // Allowed permission to user. Priority is less than deny.
'deny' => ['temp1'], // Deny permission to user. Priority is higher than allow.
]
canAccess('temp1');
// false
canAccess('temp1');
// true or false
Authentication not required
canPublicAccess();
// true or false
$accessId
, By default it check current route and return response in boolean value, And it can check access of perticular user by passing user id ($requestForUserId)
parameter. YesAuthority::check('temp1');
// true or false
Authentication not required
$accessId
, By default it check current route and return response in boolean value. YesAuthority::isPublicAccess('temp1');
// true or false
@canAccess()
// your logic here.
@endAccess;
Authentication not required
@canPublicAccess()
// your logic here.
@endAccess;