ohhink / rrm
Laravel RBAC based on Laravel-Permission with backend UI
Installs: 124
Dependents: 0
Suggesters: 0
Security: 0
Stars: 3
Watchers: 1
Forks: 0
Open Issues: 0
Language:JavaScript
Type:lib
Requires
- php: ^7.2
- earnp/laravel-google-authenticator: dev-master
- predis/predis: ^1.1
- simplesoftwareio/simple-qrcode: ^2.0.0
- spatie/laravel-permission: ^3.0
This package is auto-updated.
Last update: 2024-12-08 13:05:49 UTC
README
This Package is used for rules controller which based on roles
This package is based on Laravel Permission and can build a rule controller panel with UI in few minutes.
Server Requirements:
- Php >= 7.2
- Laravel Version >= 6.1 && < 7.0 (Not Support for Laravel Version >= 7.0 , will update soon)
what include
Const
The rule in this novel can be regards as route in Laravel
Why I do this
Word is cheap , show me the code !
Laravel Permission is a very good package without UI. So, this package is add UI on the laravel permission package and do some things to make the panel can be built quickly
What Include:
- Rule controller based on Role , you can add more than one roles to a user .
- Add more than one rules to a role .
- Menus can be different as it depends on the rules the user have .
- Write your new rules in the
routes/web.php
and it can be add in the program through one button - Record the operation, you can choose to use job to do it sync/async
- Backend ui panel
- Google Authenticator
Installation
Recommend to use new Laravel Project Remember to open
exec
,shell_exec
,proc*
functions inphp.ini
Update the local configure file .env
# change database and key # change cache CACHE_DRIVER=redis REDIS_CLIENT=predis # suggest QUEUE_CONNECTION=redis # google authenticator GOOGLE_AUTHENTICATOR=false
Run the command in the root of your new laravel project with composer
$ composer require ohhink/rrm
Publish the files , which include admin.php
,filesystems.php
,permission.php
and front resource files and database seeds files
$ php artisan vendor:publish
# if you want to reload latest package seeder, run this command in force. It will remove the origin seeder , so please be careful
$ php artisan vendor:publish --tag=seeds --force
Build the database and run the seeder
# run autoload first to update the userseeder
$ composer dump-autoload
$ php artisan migrate:refresh --seed
$ php artisan db:seed --class=RrmDatabaseSeeder
Give folder right and soft-link
$ chmod -R 777 storage $ php artisan storage:link
If you want to use Google Authenticator, you have to add this provider and aliases by yourself
// config/app.php 'providers' => [ //........ Earnp\GoogleAuthenticator\GoogleAuthenticatorServiceprovider::class, SimpleSoftwareIO\QrCode\QrCodeServiceProvider::class, ], 'aliases' => [ //.......... 'QrCode' => SimpleSoftwareIO\QrCode\Facades\QrCode::class ],
That's it !
How to use
-
The default of the backend route is
/admin
, this can be change though theconfig/admin.php
The seeder have already make a super admin user , which account is belowaccount : admin@gmail.com password : admin&%@cv..
-
What's RBAC talk about is , assign one or more rules to a role and assign one or more roles to a user. We can controller rules with a role , which we normally do rather than a detail rule. So , there is few steps you have to do with your business logic
- finish your code and add your routes in the route/web.php like you normally do
- click the Route Reload . For example , we get the new route admin.test
- create or update your translate files in the path resources/vendor/rrm/zh-cn/permission.php
- assign this new route to a role , like admin
- if this new route is a menu function, you should create a new menu and rebuild the menu otherwise the new menu will not display
-
If you want to rewrite the route , you should add below to you route/web.php
# this is rewrite the route to your app/Http/Controllers/IndexController.php index() Route::prefix(config('admin.prefix'))->middleware([ 'auth', 'admin' ])->name('admin.')->group(function () { Route::get('/', 'IndexController@index')->name('index'); });
In your app/Http/Controllers/IndexController.php file ,you should add below
public function index() { // put your code here !!! // recover the view in /resources/views/vendor/rrm/admin/index.blade.php // OR you can just run command below, it will create blade files automatically // php artisan vendor:publish --tag=views --force return view('rrm::admin.index'); }
-
To see the online-user in the right bar , you have to add command in the app/Console.Kernel.php file, like this
protected function schedule(Schedule $schedule) { // $schedule->command('inspire') // ->hourly(); $schedule->command('admin-tool:cache-online-users')->everyMinute(); }
And Remember To Add Command In Your Server
* * * * * php /home/vagrant/blade_package/artisan schedule:run >> /dev/null 2>&1
-
Since it record every step user did on panel, if you want to do it async, you can change the key val
QUEUE_CONNECTION=sync
in.env
files toQUEUE_CONNECTION=redis
This will make the recorder use jobs to async log the operations which will be faster. Of course you have to add Redis or PRedis package first -
If you want to change 500 page, you can create a resource/views/vendor/rrm/500.blade.php to rewrite that.
-
Listen Queue Command
php artisan queue:work --queue=logs --sleep=3 --tries=3 # prefer to use supervisor # supervisor config file -- laravel-worker.conf [program:logs] process_name=%(program_name)s_%(process_num)02d command=php path_to/artisan queue:work --queue=logs --sleep=3 --tries=3 autostart=true autorestart=true user=root numprocs=2 redirect_stderr=true stdout_logfile=path_to/supervisor/logs.log save and run ** supervisorctl reload ** to reload it
-
The layout of this package, you can use it though the follow code.
@extends('rrm::admin.layout') @section('content') <section id="main-content"> <section class="wrapper"> @if (Session::has('success')) @include('rrm::admin.layout.success',['msg'=>Session::get('success')]) @endif @if (Session::has('error')) @include('rrm::admin.layout.error',['msg'=>Session::get('error')]) @endif <div class="row"> <div class="col-lg-12"> </div> </div> </section> </section> @endsection @section('js') @endsection @section('css') @endsection
-
Use Google Authenticator
# First , add config to the file .env GOOGLE_AUTHENTICATOR=true # After that, no matter which page the user going to visit , he will redirect to GOOGLE AUTHENTICATOR PAGE. # Follow the step and it will redirect to the normal page after register. # If you what to vertify in your code , you can learn from the fake code. public function index() { // $google code which is registered before // $vertify code to be verified if (\OhhInk\Rrm\Model\Google::CheckCode($google, $vertify)) { // pass } else { // fail } }
Related Efforts
- Laravel Permission - Associate users with permissions and roles
Maintainers
Contributing
Feel free to dive in! Open an issue or submit PRs.
Standard Readme follows the Contributor Covenant Code of Conduct.
License
MIT © OhhInk