techlify-inc/laravel-rbac

Role Based Access Control for Laravel

1.2.2 2019-08-05 16:35 UTC

This package is not auto-updated.

Last update: 2024-04-23 07:24:12 UTC


README

Just another Role Based Access Control package for Laravel. This one focuses on keeping things simple & sweet.

Installation

Install this package with composer using the following command:

composer require techlify-inc/laravel-rbac

Run migrations

$ php artisan migrate

Add the Rbac trait to your User model

class User extends Authenticatable
{
    use TechlifyInc\LaravelRbac\Traits\LaravelRbac;
}

Usage

Roles

Creating roles

use \TechlifyInc\LaravelRbac\Models\Role;

$adminRole = Role::create([
    'name' => 'Administrator',
    'slug' => 'admin'
]);

$managerRole = Role::create([
    'name' => 'Manager',
    'slug' => 'manager'
]);

Assigning And Removing Roles

You can simple attach role to user:

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:

$user->detachRole($adminRole);
//or you can remove using the role slug
$user->detachRole("admin");

Checking for roles

You can simple check if user has role:

use App\User;

$user = User::find(1);
if ($user->hasRole('admin')) {
    
}

Permissions

Creating permissions

use \TechlifyInc\LaravelRbac\Models\Permission;

$createPermission = Permission::create([
    'name' => 'Create product',
    'slug' => 'product.create'
]);

$removePermission = Permission::create([
    'name' => 'Delete product',
    'slug' => 'product.remove'
]);

Attaching And Detaching permissions

You can attach permission to role very simple:

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:

$adminRole->detachPermission($createPermission);
$adminRole->detachPermission("product.create");

Checking for permissions

You can simple check if user has permission:

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):

Route::get("customers", "CustomerController@index")->middleware("LaravelRbacEnforcePermission:customer_view");

LaravelUserManagement is now merged into this package

A simple package for Laravel that provides user management services

Installation

Install this package with composer using the following command:

composer require techlify-inc/laravel-user-management

Run migrations

$ php artisan migrate

Usage

This package provides the following API services that your frontend can use:

User Management

// 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}

User Password Management

// Change the current user password
POST api/user/current/update-password {current_password, new_password}

User Session Management

// 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