Wallogit.com
2017 © Pedro Peláez
Role Based Access Control for Laravel
Just another Role Based Access Control package for Laravel. This one focuses on keeping things simple & sweet., (*1)
Install this package with composer using the following command:, (*2)
composer require techlify-inc/laravel-rbac
Run migrations, (*3)
$ php artisan migrate
Add the Rbac trait to your User model, (*4)
class User extends Authenticatable { use TechlifyInc\LaravelRbac\Traits\LaravelRbac; }
use \TechlifyInc\LaravelRbac\Models\Role;
$adminRole = Role::create([
'name' => 'Administrator',
'slug' => 'admin'
]);
$managerRole = Role::create([
'name' => 'Manager',
'slug' => 'manager'
]);
You can simple attach role to user:, (*5)
use App\User;
$user = User::find(1);
$user->attachRole($adminRole);
//or you can attach using the role slug
$user->attachRole("admin");
And the same if you want to detach role:, (*6)
$user->detachRole($adminRole);
//or you can remove using the role slug
$user->detachRole("admin");
You can simple check if user has role:, (*7)
use App\User;
$user = User::find(1);
if ($user->hasRole('admin')) {
}
use \TechlifyInc\LaravelRbac\Models\Permission;
$createPermission = Permission::create([
'name' => 'Create product',
'slug' => 'product.create'
]);
$removePermission = Permission::create([
'name' => 'Delete product',
'slug' => 'product.remove'
]);
You can attach permission to role very simple:, (*8)
use \TechlifyInc\LaravelRbac\Models\Role;
$adminRole = Role::find(1);
$adminRole->attachPermission($createPermission);
//or you can insert only slug
$adminRole->attachPermission("product.create");
And the same to detach permission:, (*9)
$adminRole->detachPermission($createPermission);
$adminRole->detachPermission("product.create");
You can simple check if user has permission:, (*10)
use App\User;
$user = User::find(1);
if ($user->hasPermission('product.create')) {
}
// OR for currently logged in user
if (auth()->user()->hasPermission('product.create'))
You can also enforce permissions at route level using the middleware (v0.2 onwards):, (*11)
Route::get("customers", "CustomerController@index")->middleware("LaravelRbacEnforcePermission:customer_view");
A simple package for Laravel that provides user management services, (*12)
Install this package with composer using the following command:, (*13)
composer require techlify-inc/laravel-user-management
Run migrations, (*14)
$ php artisan migrate
This package provides the following API services that your frontend can use:, (*15)
// Get the set of users GET api/users // Get a single user GET api/users/{id} // Add a new user POST api/users // Update a user record PATCH api/users/{id} // Delete a user record DELETE api/users/{id}
// Change the current user password POST api/user/current/update-password {current_password, new_password}
// Log out the currently logged in user POST api/user/logout // Get the User record of the currently logged in user GET api/user/current